共 12 条评论关于"浅谈对JavaScript中的闭包的理解及常见应用场景"
最新评论
闭包是指有权访问另一个函数作用域中的变量的函数,个人认为闭包最大的用处就是防止对全局作用域的污染。 试想如果我们把一些仅仅只用到一两次的变量都声明在全局作用域中,最后肯定是容易出错且不可维护的。而闭包最神奇的地方就是能在一个函数外访问函数中的局部变量,把这些变量用闭包的形式放在函数中便能避免污染。
《JavaScript高级程序设计》中写道:“闭包是指有权访问另一个函数作用域中的变量的函数”,如果用下定义的观点看,这句话就是说“闭包是函数”,我带着怀疑的心态又去网上找了找,发现什么说法都有,终究没能明白闭包的含义,还是看代码来得直接。
1 2 3 4 5 6 7 8 9 | function outter(){ var sky="blue"; function inner(){ console.log(sky); } return inner; } var result=outter(); result(); //"blue" |
这段代码就包含一个简单的闭包:outter函数的返回值是一个函数,即inner。inner在outter内部,理所当然能访问到局部变量sky,但当inner作为outter的返回值赋给outter外的全局变量时,神奇的事情发生了:在全局作用域中访问到了sky,这就是闭包。
每个函数都有自己的执行环境,当一个函数被执行时,它的执行环境就会被推入环境栈,其活动对象(存储环境中定义的变量及函数)加入作用域链中,一旦函数执行完,栈将其环境弹出,活动对象被销毁。
对于上面的例子来说,outter执行完之后将返回inner给了result,outter的执行环境从环境栈弹出,控制权交给全局环境,outter的活动对象理应被销毁。但此时inner已经存储在全局活动对象中了,同时inner需要访问sky,所以outter的活动对象没有被销毁,即使result执行完毕,outter的活动对象依然存在于作用域链中,只有当result被销毁
1 | result = null; |
outter的活动对象才会彻底释放。
说了这么多,闭包到底有什么用呢?我个人认为闭包最大的用处就是防止对全局作用域的污染。 试想如果我们把一些仅仅只用到一两次的变量都声明在全局作用域中,最后肯定是容易出错且不可维护的。而闭包最神奇的地方就是能在一个函数外访问函数中的局部变量,把这些变量用闭包的形式放在函数中便能避免污染。
下一篇:如何避免CSS :before、:after 中文乱码
最新评论
支付宝扫一扫打赏
微信扫一扫打赏
已经有的,那个跳动的音符点击下就是关闭导航音效
看了大有收获,真的没有白来!
值得思考哦,受教了!
[给力] 博客超赞,已收藏!建议加个关闭音效按钮,不玩那个的会觉得别扭 [呵呵]
[嘻嘻] 文字有小清新吗
666牛逼
置顶的文章都有介绍开发方案呢
怎么跟您友情链接呢 博客很不错 http://www.dingyue.pro
怎么跟您友情链接呢 博客很不错 http://www.dingyue.pro
你好,向问一下这个网页是怎么做的,您微信多少,希望求教
真想做你学生
大牛+大赞,文字小清新,我猜楼主一定是一枚美男子 [呵呵]