我是如何理解閉包中常見的問題(經(jīng)典的問題)

1词渤、首先來看一個列子
? ? ? ? ? ? ? ?

結(jié)果怎么不是我們所期望的那樣輸出1,2,3?
由這個列子在進行深擴展至我們平時項目中遇到的一種情況

輸出結(jié)果是:
我點擊的是第7個li元素喧务,結(jié)果顯示的為第10個li元素

我點擊的是第5個li元素赖歌,結(jié)果顯示的為第10個li元素

我點擊的是第4個li元素,結(jié)果顯示的為第10個li元素

我點擊的是第7個li元素功茴,結(jié)果顯示的為第10個li元素
這和第一例子輸出的結(jié)果都沒有達到自己期望的那樣庐冯,為什么會出現(xiàn)這種情況了,我的理解如下
1坎穿、首先這個和js的作用域鏈的產(chǎn)生即詞法作用域 和執(zhí)行上下文有關(guān)系
js的作用域大概包過如下三種:global? function eval 展父,主要來說說function,js的作用域的產(chǎn)生為靜態(tài)的作用域即在該函數(shù)創(chuàng)建時刻就產(chǎn)生了而且不會改變
比如
var a = 2;
function test(){
console.log(a);
}
function b (){
var a =3;
test();
}
b();//結(jié)果為2而不是3
這個就是因為js的作用域是在函數(shù)創(chuàng)建的時候就已經(jīng)確定下來了玲昧,當執(zhí)行到test函數(shù)的時候它會先去自己的作用域鏈上去查找變量a栖茉,此時在test形成的函數(shù)作用域中并沒有查找到變量a,然后它就繼續(xù)按照自己的作用域鏈向上查找結(jié)果在全局作用域中匹配到變量a...
了解這個原理之后我們在回到之前講過的那個函數(shù)中來看
var clickObj = document.getElementsByTagName('li');
//為每一個li元素添加一個點擊事件
for(var i= 0;i<clickObj.length;i++){
var clickObj[i].index = i;
clickObj[i].onclick = function(){
console.log(i);
? }
}//完整的代碼請看上面
//結(jié)果就是無論你點擊哪個li標簽打印出來的都是10(clickObj.length的值)
先來一步一步進行分析
1:初始化頁面的時候開始執(zhí)行for循環(huán)里的代碼這樣就為每個li元素都綁定了點擊事件孵延,在點擊事件觸發(fā)之前for循環(huán)已經(jīng)執(zhí)行完畢吕漂,此時i的值為10,也就是頁面初始化后全局變量i的值為10尘应,當你觸發(fā)點擊事件后惶凝,該點擊事件函數(shù)會進行i值的查找,最終他在全局作用域里找到了變量i的值此時i的值為10犬钢,所以無論你點擊哪個li苍鲜,輸出結(jié)果都是10;
為了輔助理解:可以參考下面例子

那既然了解產(chǎn)生的原因那么我們該如何去解決該問題了

2.產(chǎn)生上述結(jié)果的主要原因在于閉包的影響玷犹,如果能將每次循環(huán)后點擊事件函數(shù)的作用域都不一樣混滔,這樣問題不就可以解決了嗎,將上述函數(shù)進行改造:

輸出結(jié)果就是我們所期望的了

這個就是利用每次循環(huán)后給每一個點擊事件函數(shù)在初始化時提供對應的i值箱舞,在進入執(zhí)行上下文后也就是執(zhí)行點擊函數(shù)時,會根據(jù)作用域鏈從子向父進行查找遍坟,每個不同li元素的點擊事件函數(shù)都形成一個單獨的閉包,所以每次點擊后返回的i值就是對應于那個函數(shù)形成的閉包中的i晴股;

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末愿伴,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子电湘,更是在濱河造成了極大的恐慌隔节,老刑警劉巖鹅经,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異怎诫,居然都是意外死亡瘾晃,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門幻妓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蹦误,“玉大人,你說我怎么就攤上這事肉津∏恳龋” “怎么了?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵妹沙,是天一觀的道長偶洋。 經(jīng)常有香客問我,道長距糖,這世上最難降的妖魔是什么玄窝? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮悍引,結(jié)果婚禮上恩脂,老公的妹妹穿的比我還像新娘。我一直安慰自己吗铐,他們只是感情好东亦,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著唬渗,像睡著了一般典阵。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上镊逝,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天壮啊,我揣著相機與錄音,去河邊找鬼撑蒜。 笑死歹啼,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的座菠。 我是一名探鬼主播狸眼,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼浴滴!你這毒婦竟也來了拓萌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤升略,失蹤者是張志新(化名)和其女友劉穎微王,沒想到半個月后屡限,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡炕倘,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年钧大,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片罩旋。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡啊央,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出瘸恼,到底是詐尸還是另有隱情劣挫,我是刑警寧澤,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布东帅,位于F島的核電站,受9級特大地震影響球拦,放射性物質(zhì)發(fā)生泄漏靠闭。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一坎炼、第九天 我趴在偏房一處隱蔽的房頂上張望愧膀。 院中可真熱鬧,春花似錦谣光、人聲如沸檩淋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蟀悦。三九已至,卻和暖如春氧敢,著一層夾襖步出監(jiān)牢的瞬間日戈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工孙乖, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留浙炼,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓唯袄,卻偏偏與公主長得像弯屈,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子恋拷,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 《ijs》速成開發(fā)手冊3.0 官方用戶交流:iApp開發(fā)交流(1) 239547050iApp開發(fā)交流(2) 10...
    葉染柒丶閱讀 5,123評論 0 7
  • <a name='html'>HTML</a> Doctype作用资厉?標準模式與兼容模式各有什么區(qū)別? (1)、<...
    clark124閱讀 3,474評論 1 19
  • 第一部分 準入訓練 第1章 進入忍者世界 js開發(fā)人員通常使用js庫來實現(xiàn)通用和可重用的功能梅掠。這些庫需要簡單易用酌住,...
    如201608閱讀 1,350評論 1 2
  • 驕陽下的白蓮花 致孟鑫老師 你一個鄉(xiāng)村女孩 身著白色的連衣裙 猶如驕陽下的一朵白蓮花 ...
    鳴鷗閱讀 888評論 29 10
  • 今天第二次聽古典老師的直播課店归,古典老師的觀點對我來說,總是感覺到很新穎酪我。有興趣的朋友消痛,可以看下他寫的《拆掉思維的墻...
    幸福happy閱讀 174評論 2 1