国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

javascript自啟動(dòng)函數(shù)的問(wèn)題探討

2024-05-06 15:52:45
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
自啟動(dòng)函數(shù)想必大家并不陌生吧,在本文將為大家詳細(xì)探討下,感興趣的朋友可不要錯(cuò)過(guò)

話不多說(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);
}


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代碼的效果。

如果你能看出來(lái)效果的區(qū)別,那么恭喜你。至少我思考了很久,才明白里面的玄妙。

是的。你沒(méi)有看錯(cuò),這里的第一段代碼,無(wú)論你點(diǎn)擊哪一個(gè)鏈接,輸出的都是 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ā)的時(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)存中.

}


這里可能需要一些javascript閉包的知識(shí)。

以上代碼,想了很久,記錄下來(lái),以防止忘記。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 鲁甸县| 明溪县| 兴安县| 米林县| 宜君县| 武威市| 新疆| 武安市| 桂阳县| 兰考县| 宣威市| 黄山市| 屏边| 尼玛县| 抚宁县| 海宁市| 和龙市| 榆中县| 繁峙县| 嘉荫县| 连州市| 托克逊县| 泽普县| 郴州市| 安庆市| 隆昌县| 乌拉特后旗| 松江区| 且末县| 桐城市| 茂名市| 陇西县| 湟中县| 和静县| 法库县| 徐水县| 抚松县| 岳阳县| 曲靖市| 清镇市| 白银市|