javascript自啟動函數(shù)的問題探討
更新時間:2013年10月05日 15:08:47 作者:
自啟動函數(shù)想必大家并不陌生吧,在本文將為大家詳細探討下,感興趣的朋友可不要錯過
話不多說了。
先來看兩段代碼:
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代碼的效果。
如果你能看出來效果的區(qū)別,那么恭喜你。至少我思考了很久,才明白里面的玄妙。
是的。你沒有看錯,這里的第一段代碼,無論你點擊哪一個鏈接,輸出的都是 I am link # 8.
第二段代碼,才是你真正想要的結(jié)果,那么為什么呢。
看下面的代碼:
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ā)的時候才會啟動
//一樣,這里的i的值也一樣在循環(huán)結(jié)束的時候也變化了
}, 'false');
//原因在于
//這里的elems[i] 雖然是引用的元素
//但是回調(diào)函數(shù)中的i 已經(jīng)在循環(huán)結(jié)束后
//變成了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);
//而這里的則不一樣
//雖然循環(huán)結(jié)束后i 的值變成了8
//但是在封裝在閉包內(nèi)的index 確實一直被locked 住的
//一直保存在內(nèi)存中。
//準確的說 應(yīng)該是整個函數(shù)都lock在內(nèi)存中.
}
這里可能需要一些javascript閉包的知識。
以上代碼,想了很久,記錄下來,以防止忘記。
先來看兩段代碼:
復(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);
}
HTML 代碼如下:
復(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>
你可以想像下,前后兩段 script代碼的效果。
如果你能看出來效果的區(qū)別,那么恭喜你。至少我思考了很久,才明白里面的玄妙。
是的。你沒有看錯,這里的第一段代碼,無論你點擊哪一個鏈接,輸出的都是 I am link # 8.
第二段代碼,才是你真正想要的結(jié)果,那么為什么呢。
看下面的代碼:
復(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ā)的時候才會啟動
//一樣,這里的i的值也一樣在循環(huán)結(jié)束的時候也變化了
}, 'false');
//原因在于
//這里的elems[i] 雖然是引用的元素
//但是回調(diào)函數(shù)中的i 已經(jīng)在循環(huán)結(jié)束后
//變成了8(如果 elems 的長度是 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 確實一直被locked 住的
//一直保存在內(nèi)存中。
//準確的說 應(yīng)該是整個函數(shù)都lock在內(nèi)存中.
}
這里可能需要一些javascript閉包的知識。
以上代碼,想了很久,記錄下來,以防止忘記。
相關(guān)文章
JavaScript模塊規(guī)范之AMD規(guī)范和CMD規(guī)范
本篇文章給大家介紹js模塊規(guī)范之AMD規(guī)范和CMD規(guī)范,模塊化是一種處理復(fù)雜系統(tǒng)分解為代碼結(jié)構(gòu)更合理,可維護性更高的可管理的模塊的方式,對js amd cmd規(guī)范感興趣的童鞋可以來本文學(xué)習(xí)2015-10-10JS實現(xiàn)圖片元素轉(zhuǎn)BASE64編碼的簡單示例
在Web開發(fā)中,我們經(jīng)常需要將圖片轉(zhuǎn)換為Base64格式,以便在不依賴外部資源的情況下直接在HTML中使用,在這篇文章中,我將向您展示如何使用JavaScript將圖片元素轉(zhuǎn)BASE64編碼,需要的朋友可以參考下2023-12-12JavaScript原生對象之Number對象的屬性和方法詳解
這篇文章主要介紹了JavaScript原生對象之Number對象的屬性和方法詳解,本文講解了創(chuàng)建 Number 對象的語法、MAX_VALUE、MIN_VALUE、NaN等屬性或方法,需要的朋友可以參考下2015-03-03

JavaScript原型繼承_動力節(jié)點Java學(xué)院整理
這篇文章主要為大家詳細介紹了JavaScript原型繼承的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
2017-06-06