关于JavaScript闭包的个人思考与应用
来源:互联网 发布:上网淘宝 编辑:程序博客网 时间:2024/06/05 11:40
一、闭包的概念
以上的闭包解释其实已经不局限于JavaScript了,其实很多语言都支持闭包这个概念。下面我来通俗的说一下我对闭包的理解——闭包就是可以用于访问其他函数内部变量并且将其“包养”起来的函数。下面通过代码来讲解下作用域进而引出闭包的使用。
二、作用域与闭包
代码一:
var name = "The Window";var object = { name : "My Object", getNameFunc : function(){ return function(){ return this.name; }; }};alert(object.getNameFunc()());
代码二:
var name = "The Window";var object = { name : "My Object", getNameFunc : function(){ var that = this; return function(){ return that.name; }; }};alert(object.getNameFunc()());
代码一 执行弹出来的是“The Window”,代码二执行弹出来的时“My Object”。
结果解释:代码二中的getNameFunc方法比代码一中多定义了一个that变量并且将它指向this,当它执行到object.getNameFunc()()得到了内部嵌套函数返回的that.name,此时that这个变量在嵌套函数中并没有定义,于是它就会到定义这个嵌套函数的作用域(getNameFunc函数内的作用域)中找that,由于嵌套函数中使用了外部getNameFunc函数中定义的that,所以在执行完object.getNameFunc()这个方法后,that变量保存依然在内存中,这便是闭包的神奇之处,由于that=this,而此时this指向的是调getNameFunc方法的对象即object,所以that.name="My Object"。
而在在代码一中在执行完object.getNameFunc()()得到了内部嵌套函数返回的this.name,此时由于this在嵌套函数中,this并不指向调用getNameFunc方法的object,而是指向全局变量Window,this.name=Window,name 于是便得到了“The Window” 。
总结:要理解闭包得先理解作用域的概念,当函数内部引用了了自由变量(函数体内没有定义的变量),函数便会到定义自己的作用域中找这个变量,而这个变量在这个函数执行之前会一直保存在内存中(尽管定义它的方法执行完)等待调用,我们可以将调用该自由变量的函数看成闭包,闭包“包养”了这个自由变量。
三、闭包的使用
现有如下html结构
<ul> <li>click me</li> <li>click me</li> <li>click me</li> <li>click me</li></ul>
var elements=document.getElementsByTagName('li'); var length=elements.length; for(var i=0;i<length;i++){ elements[i].onclick=function(){ alert(i); } }结果分别依次点击4个li标签弹出的均为“4”,而不是”0“,”1“,”2“,”3“这是为什么呢?
因为绑定的事件方法是异步执行的,当他们还没有执行的时候,for循环就完毕了,此时i=4,而每个事件函数中的alert(i),均指向全局变量i,所以弹出的都是“4”。
下面我们用闭包“包养”自由变量 这一特性,让它依次弹出”0“,”1“,”2“,”3“,将JavaScript按如下写:
var elements=document.getElementsByTagName('li'); var length=elements.length; for(var i=0;i<length;i++){ elements[i].onclick=(function(a){ return function(){ alert(a); } })(i); }//用此代码可以依次弹出 0,1,2,3(闭包可以“包养”外部函数变量
可以包养每一次传入的i值,将它保存在内存中,于是就达到了目的。
以上只是个人的一些思考,可能表述有误,欢迎指正!
- 关于JavaScript闭包的个人思考与应用
- JavaScript 关于闭包的思考 总结
- JavaScript 关于闭包的思考 总结
- 关于Spring AOP与IOC的个人思考
- 关于个人综合能力的个人思考
- javascript闭包的个人理解
- 关于闭包的一些学习思考
- javascript闭包的应用
- javascript闭包的应用
- javascript闭包的应用
- 关于闭包的个人理解
- 关于JavaScript的闭包
- 关于 Javascript 的闭包
- 关于javascript的闭包
- 关于javascript闭包与重构
- 关于 HTML5 应用现状与前景的思考
- 关于 HTML5 应用现状与前景的思考
- 关于个人价值、职业规划、婚姻的思考
- Spring io 2015-08-27 10:49:13.774 WARN 1718 --- [nio-8080-exec-1] o.s.web.servlet.PageNotFound
- 欢迎使用CSDN-markdown编辑器
- 观察者模式
- iOS push 导航栏显示 隐藏
- Eclipse更改字体大小
- 关于JavaScript闭包的个人思考与应用
- 数据库设计的三范式
- Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句
- PHP初学分享-数据类型
- Android 入门笔记2--启动界面SplashActivity
- MyBatis之java.lang.UnsupportedOperationException异常解决方案
- mysql-安装之CAMKE编译安装
- JNI数据类型转换
- 正则表达式在notepad++中的使用