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

首頁 > 編程 > JavaScript > 正文

javascript自啟動函數的問題探討

2019-11-20 21:55:15
字體:
來源:轉載
供稿:網友
話不多說了。

先來看兩段代碼:
復制代碼 代碼如下:

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閉包的知識。

以上代碼,想了很久,記錄下來,以防止忘記。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 靖江市| 綦江县| 北海市| 定兴县| 濉溪县| 阿拉尔市| 霍林郭勒市| 余庆县| 德保县| 清河县| 宜宾市| 隆林| 通化县| 霸州市| 晋江市| 彭阳县| 承德县| 朝阳区| 抚宁县| 石家庄市| 历史| 麻城市| 莆田市| 白沙| 元氏县| 惠州市| 尚义县| 江北区| 宝应县| 尚义县| 道孚县| 兖州市| 清远市| 政和县| 葫芦岛市| 当阳市| 黄陵县| 灵宝市| 乐清市| 秭归县| 汶川县|