亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2013年10月05日 15:08:47   作者:  
自啟動(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),以防止忘記。

相關(guān)文章

  • JavaScript模塊規(guī)范之AMD規(guī)范和CMD規(guī)范

    JavaScript模塊規(guī)范之AMD規(guī)范和CMD規(guī)范

    本篇文章給大家介紹js模塊規(guī)范之AMD規(guī)范和CMD規(guī)范,模塊化是一種處理復(fù)雜系統(tǒng)分解為代碼結(jié)構(gòu)更合理,可維護(hù)性更高的可管理的模塊的方式,對(duì)js amd cmd規(guī)范感興趣的童鞋可以來(lái)本文學(xué)習(xí)
    2015-10-10
  • JS實(shí)現(xiàn)圖片元素轉(zhuǎn)BASE64編碼的簡(jiǎn)單示例

    JS實(shí)現(xiàn)圖片元素轉(zhuǎn)BASE64編碼的簡(jiǎn)單示例

    在Web開(kāi)發(fā)中,我們經(jīng)常需要將圖片轉(zhuǎn)換為Base64格式,以便在不依賴外部資源的情況下直接在HTML中使用,在這篇文章中,我將向您展示如何使用JavaScript將圖片元素轉(zhuǎn)BASE64編碼,需要的朋友可以參考下
    2023-12-12
  • 微信小程序如何獲取群聊的openGid以及名稱詳解

    微信小程序如何獲取群聊的openGid以及名稱詳解

    這篇文章主要介紹了小程序如何獲取群聊的openGid以及名稱詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • JavaScript原生對(duì)象之Number對(duì)象的屬性和方法詳解

    JavaScript原生對(duì)象之Number對(duì)象的屬性和方法詳解

    這篇文章主要介紹了JavaScript原生對(duì)象之Number對(duì)象的屬性和方法詳解,本文講解了創(chuàng)建 Number 對(duì)象的語(yǔ)法、MAX_VALUE、MIN_VALUE、NaN等屬性或方法,需要的朋友可以參考下
    2015-03-03
  • JS判斷圖片是否加載完成方法匯總(最新版)

    JS判斷圖片是否加載完成方法匯總(最新版)

    有時(shí)需要獲取圖片的尺寸,這需要在圖片加載完成以后才可以。下面小編給大家整理了幾種關(guān)于JS判斷圖片是否加載完成方法匯總,一起看看吧
    2016-05-05
  • javascript 雙色球?qū)Κ?jiǎng)器

    javascript 雙色球?qū)Κ?jiǎng)器

    可以檢驗(yàn)雙色球是否中獎(jiǎng)的js
    2008-04-04
  • js中函數(shù)聲明與函數(shù)表達(dá)式

    js中函數(shù)聲明與函數(shù)表達(dá)式

    js的解析器對(duì)函數(shù)聲明與函數(shù)表達(dá)式并不是一視同仁地對(duì)待的。對(duì)于函數(shù)聲明,js解析器會(huì)優(yōu)先讀取,確保在所有代碼執(zhí)行之前聲明已經(jīng)被解析,而函數(shù)表達(dá)式,如同定義其它基本類型的變量一樣,只在執(zhí)行到某一句時(shí)也會(huì)對(duì)其進(jìn)行解析,
    2015-06-06
  • JavaScript原型繼承_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    JavaScript原型繼承_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

    這篇文章主要為大家詳細(xì)介紹了JavaScript原型繼承的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • js中開(kāi)關(guān)變量使用實(shí)例

    js中開(kāi)關(guān)變量使用實(shí)例

    本文主要分享了js中開(kāi)關(guān)變量使用實(shí)例的代碼,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • 原生JS實(shí)現(xiàn)的自動(dòng)輪播圖功能詳解

    原生JS實(shí)現(xiàn)的自動(dòng)輪播圖功能詳解

    這篇文章主要介紹了原生JS實(shí)現(xiàn)的自動(dòng)輪播圖功能,結(jié)合實(shí)例形式詳細(xì)分析了基于原生js實(shí)現(xiàn)輪播圖的原理、操作步驟及操作注意事項(xiàng),需要的朋友可以參考下
    2018-12-12

最新評(píng)論