javascript自启动函数的问题探讨
            (编辑:jimmy 日期: 2025/11/1 浏览:2)
         
        话不多说了。 
先来看两段代码: 
复制代码 代码如下: 
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闭包的知识。 
以上代码,想了很久,记录下来,以防止忘记。
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。