javascript自启动函数的问题探讨_javascript技巧
程序员文章站
2022-05-10 20:18:02
...
话不多说了。
先来看两段代码:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
alert(i);
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + i);
}, 'false');
}
再看一面一段:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
(function(index){
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + index);
}, 'false');
})(i);
}
HTML 代码如下:
你可以想像下,前后两段 script代码的效果。
如果你能看出来效果的区别,那么恭喜你。至少我思考了很久,才明白里面的玄妙。
是的。你没有看错,这里的第一段代码,无论你点击哪一个链接,输出的都是 I am link # 8.
第二段代码,才是你真正想要的结果,那么为什么呢。
看下面的代码:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
alert(i);
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + i);
//注意这里的回调函数只有的触发的时候才会启动
//一样,这里的i的值也一样在循环结束的时候也变化了
}, 'false');
//原因在于
//这里的elems[i] 虽然是引用的元素
//但是回调函数中的i 已经在循环结束后
//变成了8(如果 elems 的长度是 8 的话)
}
var elems = document.getElementsByTagName('a');
for (var i = 0; i
(function(index){
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + index);
}, 'false');
})(i);
//而这里的则不一样
//虽然循环结束后i 的值变成了8
//但是在封装在闭包内的index 确实一直被locked 住的
//一直保存在内存中。
//准确的说 应该是整个函数都lock在内存中.
}
这里可能需要一些javascript闭包的知识。
以上代码,想了很久,记录下来,以防止忘记。
先来看两段代码:
复制代码 代码如下:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
alert(i);
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + i);
}, 'false');
}
再看一面一段:
复制代码 代码如下:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
(function(index){
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + index);
}, 'false');
})(i);
}
HTML 代码如下:
复制代码 代码如下:
你可以想像下,前后两段 script代码的效果。
如果你能看出来效果的区别,那么恭喜你。至少我思考了很久,才明白里面的玄妙。
是的。你没有看错,这里的第一段代码,无论你点击哪一个链接,输出的都是 I am link # 8.
第二段代码,才是你真正想要的结果,那么为什么呢。
看下面的代码:
复制代码 代码如下:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
alert(i);
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + i);
//注意这里的回调函数只有的触发的时候才会启动
//一样,这里的i的值也一样在循环结束的时候也变化了
}, 'false');
//原因在于
//这里的elems[i] 虽然是引用的元素
//但是回调函数中的i 已经在循环结束后
//变成了8(如果 elems 的长度是 8 的话)
}
复制代码 代码如下:
var elems = document.getElementsByTagName('a');
for (var i = 0; i
(function(index){
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + index);
}, 'false');
})(i);
//而这里的则不一样
//虽然循环结束后i 的值变成了8
//但是在封装在闭包内的index 确实一直被locked 住的
//一直保存在内存中。
//准确的说 应该是整个函数都lock在内存中.
}
这里可能需要一些javascript闭包的知识。
以上代码,想了很久,记录下来,以防止忘记。
推荐阅读
-
javascript随机数发现的一个parseInt函数的问题
-
JavaScript基础教程之学习过程中遇到的匿名函数问题
-
【jQuery】关于 jQuery 和 JavaScript 两个入口函数的执行顺序问题
-
JavaScript中setInterval函数应用常见问题之一(第一个参数不加引号与加引号的区别)
-
元素的内联事件处理函数的特殊作用域在各浏览器中存在差异_javascript技巧
-
javascript arguments 传递给函数的隐含参数_javascript技巧
-
JavaScript中某一标签内函数用this获取不到当前标签的问题笔记
-
javascript中onmouse事件在div中失效问题的解决方法_javascript技巧
-
几个高效,简洁的字符处理函数_javascript技巧
-
关于javaScript注册click事件传递参数的不成功问题_javascript技巧