javascript循环变量注册dom事件 之强大的闭包
更新时间:2010年09月08日 11:26:07 作者:
是在循环过程过this被改变,注册过的事件也被随之改变,找到了一种解决方法
今天遇到了这个问题:
//伪代码
for (var i=0; i<n; i++) {
addEvent(obj[i], "click", func(i));
}
结果出现了问题,所有的dom都被注册了 i=n 的时候的事件,查了一些资料,说是在循环过程过this被改变,注册过的事件也被随之改变,找到了一种解决方法;
for (var i=0; i<n; i++) {
(function (i){addEvent(obj[i], "click", function (){func(i);});})(i);
}
利用必包保持对变量的持久引用,很强大的说!
(如果您有更好的方法,请不吝赐教(*^__^*) 嘻嘻……)
复制代码 代码如下:
//伪代码
for (var i=0; i<n; i++) {
addEvent(obj[i], "click", func(i));
}
结果出现了问题,所有的dom都被注册了 i=n 的时候的事件,查了一些资料,说是在循环过程过this被改变,注册过的事件也被随之改变,找到了一种解决方法;
复制代码 代码如下:
for (var i=0; i<n; i++) {
(function (i){addEvent(obj[i], "click", function (){func(i);});})(i);
}
利用必包保持对变量的持久引用,很强大的说!
(如果您有更好的方法,请不吝赐教(*^__^*) 嘻嘻……)
您可能感兴趣的文章:
- Javascript DOM事件操作小结(监听鼠标点击、释放,悬停、离开等)
- JavaScript DOM事件(笔记)
- JavaScript call apply使用 JavaScript对象的方法绑定到DOM事件后this指向问题
- JS对象与JSON互转换、New Function()、 forEach()、DOM事件流等js开发基础小结
- 关于javascript DOM事件模型的两件事
- 谈谈我对JavaScript DOM事件的理解
- 深入理解JS DOM事件机制
- 理解javascript中DOM事件
- js中DOM事件绑定分析
- js实现QQ面板拖拽效果(慕课网DOM事件探秘)(全)
- JavaScript将DOM事件处理程序封装为event.js 出现的低级错误问题
- js DOM的事件常见操作实例详解
相关文章
JavaScript错误处理之分析 Uncaught(in promise) error的
在开发过程中,JavaScript的错误处理是一个老生常谈的话题,当应用程序发生未捕获的异常时,Uncaught(in promise) error是其中最常见的错误类型,这篇文章将从多个方面详细阐述这种错误类型的原因与解决方案,感兴趣的朋友一起看看吧2023-12-12
最新评论