javascript 常见的闭包问题的解决办法
更新时间:2009年11月06日 00:15:04 作者:
javascript 常见的闭包问题的解决办法,需要的朋友可以参考下。
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
上段代码本意是在每个div上都加一个事件,即每当点击div时,就显示此div的相应序号。但是运行程序时我们会发现,不论点击那个,只会显示7,这是什么愿因呢。--这就是闭包的问题
原来 在js中,函数中在定义函数,就出现闭包了。此时外层函数中变量是可以在里层函数里利用的,即使外层函数结束。但是当外层中出现循环的时候,如果在里层函数中利用这个循环变量的话,会直接引用这个变量的最终值。
就像上述代码演示的一样。
如何解决呢。
可以利用匿名函数来加以解决。匿名函数会制动执行,我们可以利用这一特性,来产生一个作用域,生命一个变量,来引用外层的循环变量。
如代码所示:
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
由于在内层函数里只要出现循环变量的话 都是最终值,所以我们利用匿名函数 激发出一个作用域,在进入内层循环之前,有另一变量获得该循环变量的值,这一思想是处理闭包问题的精髓。
如下例子:此时并没有明显的for循环,但是 根据上述思想,可以立即加以解决 问题
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
解决后代码:
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
补充:看到有网友这样解决了问题:
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
我个人的理解是 在进入内层循环之前 把id赋值给f,f在作为内层循环的参数,其思想应该是一样的.
相关文章
JavaScript格式化日期时间的方法和自定义格式化函数示例
JavaScript默认的时间格式我们一般情况下不会用,所以需要进行格式化,下面说说我总结的JavaScript时间格式化方法2014-04-04
JavaScript跨浏览器获取页面中相同class节点的方法
这篇文章主要介绍了JavaScript跨浏览器获取页面中相同class节点的方法,本文讲解使用getELementsByClassName函数解决这个需求,并给了一个开源的getELementsByClassName函数实现,功能更加强大,需要的朋友可以参考下2015-03-03
JavaScript实现点击自动选择TextArea文本的方法
这篇文章主要介绍了JavaScript实现点击自动选择TextArea文本的方法,涉及javascript中focus()、select()方法的使用技巧,非常简单实用,需要的朋友可以参考下2015-07-07


最新评论