話不多說(shuō)了。
先來(lái)看兩段代碼:
復(fù)制代碼 代碼如下:
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');
}
復(fù)制代碼 代碼如下:
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);
}
復(fù)制代碼 代碼如下:
<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>
復(fù)制代碼 代碼如下:
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);
//注意這里的回調(diào)函數(shù)只有的觸發(fā)的時(shí)候才會(huì)啟動(dòng)
//一樣,這里的i的值也一樣在循環(huán)結(jié)束的時(shí)候也變化了
}, 'false');
//原因在于
//這里的elems[i] 雖然是引用的元素
//但是回調(diào)函數(shù)中的i 已經(jīng)在循環(huán)結(jié)束后
//變成了8(如果 elems 的長(zhǎng)度是 8 的話)
}
復(fù)制代碼 代碼如下:
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);
//而這里的則不一樣
//雖然循環(huán)結(jié)束后i 的值變成了8
//但是在封裝在閉包內(nèi)的index 確實(shí)一直被locked 住的
//一直保存在內(nèi)存中。
//準(zhǔn)確的說(shuō) 應(yīng)該是整個(gè)函數(shù)都lock在內(nèi)存中.
}
新聞熱點(diǎn)
疑難解答
圖片精選