网络编程 
首页 > 网络编程 > 浏览文章

javascript自启动函数的问题探讨

(编辑:jimmy 日期: 2025/5/11 浏览:3 次 )
话不多说了。

先来看两段代码:
复制代码 代码如下:
var elems = document.getElementsByTagName('a');

for (var i = 0; i < elems.length; 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 < elems.length; i++) {

(function(index){
elems[i].addEventListener('click', function (e) {
e.preventDefault();
alert('I am link #' + index);
}, 'false');
})(i);
}

HTML 代码如下:
复制代码 代码如下:
<body>
<a href = "#">a</a>
<a href = "#">a</a>
<a href = "#">a</a>
<a href = "#">a</a>
<a href = "#">a</a>
<a href = "#">a</a>
<a href = "#">a</a>
<a href = "#">a</a>
</body>

你可以想像下,前后两段 script代码的效果。

如果你能看出来效果的区别,那么恭喜你。至少我思考了很久,才明白里面的玄妙。

是的。你没有看错,这里的第一段代码,无论你点击哪一个链接,输出的都是 I am link # 8.

第二段代码,才是你真正想要的结果,那么为什么呢。

看下面的代码:
复制代码 代码如下:
var elems = document.getElementsByTagName('a');

for (var i = 0; i < elems.length; 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 < elems.length; 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 函数声明与函数表达式的区别介绍
下一篇:纯js简单日历实现代码
一句话新闻
Windows上运行安卓你用过了吗
在去年的5月23日,借助Intel Bridge Technology以及Intel Celadon两项技术的驱动,Intel为PC用户带来了Android On Windows(AOW)平台,并携手国内软件公司腾讯共同推出了腾讯应用宝电脑版,将Windows与安卓两大生态进行了融合,PC的使用体验随即被带入到了一个全新的阶段。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap