位置: 编程技术 - 正文

javascript作用域和闭包使用详解(javascript 作用域)

编辑:rootadmin

作用域的嵌套将形成作用域链,函数的嵌套将形成闭包。闭包与作用域链是 JavaScript 区别于其它语言的重要特性之一。

作用域JavaScript 中有两种作用域:函数作用域和全局作用域。

在一个函数中声明的变量以及该函数的参数享有同一个作用域,即函数作用域。一个简单的函数作用域的例子:

不同于C等其它有块作用域的语言,这里将始终返回 2 。

全局作用域,对于浏览器来说可以理解为 window 对象(Node.js则是 global):

对于变量 bar 和函数 foo 都属于全局作用域,都是 window 的一个属性。

作用域链在 JavaScript 中访问一个变量时,将从本地变量和参数开始,逐级向上遍历作用域直到全局作用域。

在最里层的函数中,各个变量都能被逐级遍历并输出。而倒数第二层的函数中,变量 three 无法遍历找到,所以输出了 undefined 。

举一个通俗点的例子,你准备要花钱买点东西时,会先摸摸自己的钱包,没了你可以找你爸要,你爸也没有就再找你爷爷,... 。而你爸没钱买东西时,他并不会来找你要。

闭包在一个函数中,定义另一个函数,称为函数嵌套。函数的嵌套将形成一个闭包。

闭包与作用域链相辅相成,函数的嵌套在产生了链式关系的多个作用域的同时,也形成了一个闭包。

那么怎么理解闭包呢?

外部函数不能访问内嵌函数外部函数也不能访问内嵌函数的参数和变量而内嵌函数可以访问外部函数的参数和变量换一个说法:内嵌函数包含了外部函数的作用域我们再看看之前讲述的作用域链的例子,这次从闭包的角度来理解下:

最里层的函数能访问到其内部和外部定义的所有变量。而倒数第二层的函数无法访问到最里层的变量,同时,最里层的 scope = 3 这个赋值操作并没有对其外部的同名变量产生影响。

再换个角度来理解闭包:

每次外部函数的调用,内嵌函数都会被创建一次在它被创建时,外部函数的作用域(包括任何本地变量、参数等上下文), 会成为每个内嵌函数对象的内部状态的一部分,即使在外部函数执行完并退出后看下面的例子:

我们将得到两次 "2" ,而不是预期的 "1" 和 "2" ,这是因为在 list 中的两个函数访问的变量 i 都是其上一层作用域的同一个变量。

我们改动下代码,以利用闭包来解决这个问题:

外层的“立即执行函数”接收了一个参数变量 i ,在其函数内以参数 j 的形式存在,它与被返回的内层函数中的名称 j 指向同一个引用。外层函数执行并退出后,参数 j (此时它的值为 i 的当前值)成为了其内层函数的状态的一部分被保存了下来。

推荐整理分享javascript作用域和闭包使用详解(javascript 作用域),希望有所帮助,仅作参考,欢迎阅读内容。

javascript作用域和闭包使用详解(javascript 作用域)

文章相关热门搜索词:js作用域链是什么,js有哪些作用域,分别是什么意思,javascript作用域有几种,js作用域和作用域链的理解阮一峰,javascript作用域和闭包,js作用域与作用域链,javascript作用域和闭包,javascript作用域链,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript实现存储hmtl字符串示例 Function.prototype.heredoc=function(){//利用function的注释来存储字符串,而且无需转义。var_str=this.toString(),s_pos=_str.indexOf("/*")+2,e_pos=_str.lastIndexOf("*/");return(s_pos0||

对js关键字命名的疑问介绍 js对关键字命名我感觉有点乱有时候是这样:getElementById、indexOf、charCodeAt、parseFloat、navigator.appName、navigator.appVersion/appCodeName/cookieEnable/userAgent给人的感

js对象内部访问this修饰的成员函数示例 用wrapper封装这样在对象内外都可以访问functionMapPool(){functioncreateMarker(name,lat,lng,state){varmarker=newAMap.Marker({position:newAMap.LngLat(lng,lat),});//thefunctionmapMoveToisnot

标签: javascript 作用域

本文链接地址:https://www.jiuchutong.com/biancheng/373790.html 转载请保留说明!

上一篇:js检测浏览器版本、核心、是否移动端示例(js查看浏览器信息)

下一篇:javascript实现存储hmtl字符串示例(js存储)

  • 小规模销售免税农产品的分录
  • 单位购买定制的器材
  • 被财政收回的财政经费如何做财务处理?
  • 周转材料调拨调入单位如何做账
  • 收到股东增资款账务处理怎么做账
  • 行政单位的存货是什么
  • 固定资产发票未到可以确认固定资产吗
  • 公司支付给股东付银行利息要交税吗怎么交
  • 怎么查找地方教育附加税的计税依据?
  • 前期差错更正处理方法
  • 增值税如何确认
  • 小微企业免征增值税优惠
  • 在建工程摊销是啥意思
  • 企业所得税期间费用明细表
  • 二手店铺转让手续流程
  • 全资子公司向母公司提供劳务服务怎么做账
  • 买入返售金融资产什么意思
  • 会计审核票据如何签字
  • 失控发票一定要盖章吗
  • 研发费中废料收入怎么处理
  • win7系统重启怎么还原系统
  • 安装win7系统的硬件要求
  • 咨询服务费怎么交税
  • PHP:curl_multi_add_handle()的用法_cURL函数
  • PHP:stream_get_transports()的用法_Stream函数
  • 工厂采购部门
  • vue设置时间格式
  • 房地产企业购地印花税如何入账
  • 特殊性税务处理的条件
  • ant design pro项目构建纯净版
  • 跨年庆典中燃放的歌曲
  • 滴滴发票4月1日怎么开
  • javascript - localStorage 本地存储(新增、删除、修改)使用教程
  • 机器学习中的预测评价指标MSE、RMSE、MAE、MAPE、SMAPE
  • yolov5 test.py
  • flip函数
  • 专用发票费率
  • SQL Server 使用 SET FMTONLY ON 获得表的元数据
  • sqlite时间戳转时间语句(时间转时间戳)
  • 资金账簿印花税减半政策
  • sql2017附加数据库
  • 开了发票不做收入的账务处理是?
  • mysql三种安装方式
  • 工程的直接成本包括哪些内容
  • 怎么才能不开发票
  • 所得税减免的会计科目
  • 建筑发票开具与土增税扣有什么关系?
  • 销售折让的会计分录怎么做
  • 工资走公账有什么好处
  • 免费给人一些客户资料违法吗
  • 亏本处理产品怎么做账
  • 暂估出库需要确认收入吗
  • 补偿款怎么写才能有效
  • 新注册公司工商如何做印章确认
  • 会计分录要怎么写
  • mysql null+1
  • xp系统运行怎么打开
  • 修改文件软件免费下载
  • ubuntu20.04 vim
  • win8提升模式
  • xp系统电源设置在哪里
  • linux系统简介
  • xp系统部分乱码解决
  • make:arm-linux- conmand not found错误处理探讨
  • win7怎么隐藏软件
  • linux怎么查看挂载点
  • 简述javascript中的函数
  • 贴吧热门评论
  • bootstrap按钮的风格有哪些?
  • win7支持快速启动吗
  • android的intent介绍
  • 简述javascript的作用
  • linux tomcat命令
  • uleb128、sleb128和uleb128p1编码格式介绍
  • javascriptz
  • 基于javascript的毕业设计
  • edittext获取焦点弹出键盘
  • 纳税人信用信息
  • 骗取国家出口退税罪
  • 农转非和非农
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设