首頁 > web前端 > js教程 > 主體

JavaScript在for迴圈中綁定事件解決事件參數不同的情況_javascript技巧

WBOY
發布: 2016-05-16 17:03:14
原創
1084 人瀏覽過

有時候要對回應一堆相似的事件,但是每個事件的參數都不同,一開始還以為挺簡單的,用個for循環不就得了,結果發現,額,都是使用了最後一個參數。 。 。

上網查資料! ! !結果大神說用閉包解決

代碼:

複製程式碼 代碼如下:

代碼如下:for(var i=0;ibtns[i].onclick=(function(i){
return function(){alert(i)}
} )(i)
}


大概原因是直接用btns[i].onclick=function(){alert(i)}時,JavaScript引擎會先將for迴圈裡的程式碼執行完,

當使用者出發onclick事件時,JavaScript會尋找i,結果會找到運算完成之後的i,也就是10
但是用閉包處理的話,i會成為函數的局部變數
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板