javascript使用for循環(huán)批量注冊的事件不能正確獲取索引值的解決方法
本文實(shí)例講述了javascript使用for循環(huán)批量注冊的事件不能正確獲取索引值的解決方法。分享給大家供大家參考。具體分析如下:
可能不少朋友會(huì)遇到一個(gè)問題,那就是當(dāng)使用for循環(huán)批量注冊事件處理函數(shù),然后最后通過事件處理函數(shù)獲取當(dāng)前元素的索引值的時(shí)候會(huì)失敗,先看一段代碼實(shí)例:
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.dbjr.com.cn/" />
<title>腳本之家</title>
<style type="text/css">
li{
width:240px;
overflow:hidden;
text-overflow:ellipsis;
white-space:nowrap;
font-size:12px;
height:30px;
}
</style>
<script type="text/javascript">
window.onload=function(){
var oLis=document.getElementsByTagName("li");
var oshow=document.getElementById("show");
for(var index=0;index<oLis.length;index++){
oLis[index].onclick=function(){
oshow.innerHTML=index;
}
}
}
</script>
</head>
<body>
<div id="show"></div>
<ul>
<li>只有努力奮斗才會(huì)有美好的明天。</li>
<li>分享互助是進(jìn)步最大的源動(dòng)力。</li>
<li>每一天都是新的,要好好珍惜。</li>
<li>沒有人一開始就是高手,只有努力才有成長的可能</li>
<li>只有當(dāng)下的時(shí)間是可貴的,下一秒都是虛幻的</li>
</ul>
</body>
</html>
在上面的代碼中,當(dāng)點(diǎn)擊li元素的時(shí)候彈出值始終是四,我們本來的想法是,點(diǎn)擊li元素在div中顯示當(dāng)前l(fā)i元素的索引值,下面就簡單分析一下其中的原因。原因非常的簡單,當(dāng)for循環(huán)執(zhí)行完畢以后,index的值已經(jīng)變?yōu)樗模谑且簿统霈F(xiàn)了上面的現(xiàn)象。
代碼修改如下:
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.dbjr.com.cn/" />
<title>腳本之家</title>
<style type="text/css">
li{
width:240px;
overflow:hidden;
text-overflow:ellipsis;
white-space:nowrap;
font-size:12px;
height:30px;
}
</style>
<script type="text/javascript">
window.onload=function(){
var oLis=document.getElementsByTagName("li");
var oshow=document.getElementById("show");
for(var index=0;index<oLis.length;index++){
oLis[index]._index=index;
oLis[index].onclick=function(){
oshow.innerHTML=this._index;
}
}
}
</script>
</head>
<body>
<div id="show"></div>
<ul>
<li>只有努力奮斗才會(huì)有美好的明天。</li>
<li>分享互助是進(jìn)步最大的源動(dòng)力。</li>
<li>每一天都是新的,要好好珍惜。</li>
<li>沒有人一開始就是高手,只有努力才有成長的可能</li>
<li>只有當(dāng)下的時(shí)間是可貴的,下一秒都是虛幻的</li>
</ul>
</body>
</html>
上面的代碼實(shí)現(xiàn)了我們的要求,當(dāng)然也可以使用閉包的方式,代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.dbjr.com.cn/" />
<title>腳本之家</title>
<style type="text/css">
li{
width:240px;
overflow:hidden;
text-overflow:ellipsis;
white-space:nowrap;
font-size:12px;
height:30px;
}
</style>
<script type="text/javascript">
window.onload=function(){
var oLis=document.getElementsByTagName("li");
var oshow=document.getElementById("show");
for(var index=0;index<oLis.length;index++){
(function(index){
oLis[index].onclick=function(){
oshow.innerHTML=index;
}
})(index)
}
}
</script>
</head>
<body>
<div id="show"></div>
<ul>
<li>只有努力奮斗才會(huì)有美好的明天。</li>
<li>分享互助是進(jìn)步最大的源動(dòng)力。</li>
<li>每一天都是新的,要好好珍惜。</li>
<li>沒有人一開始就是高手,只有努力才有成長的可能</li>
<li>只有當(dāng)下的時(shí)間是可貴的,下一秒都是虛幻的</li>
</ul>
</body>
</html>
希望本文所述對大家基于javascript的web程序設(shè)計(jì)有所幫助。
- javascript下for循環(huán)用法小結(jié)
- javascript之循環(huán)停頓上下滾動(dòng)
- javascript中利用數(shù)組實(shí)現(xiàn)的循環(huán)隊(duì)列代碼
- javascript 循環(huán)讀取JSON數(shù)據(jù)的代碼
- javascript forEach通用循環(huán)遍歷方法
- javascript 循環(huán)語句 while、do-while、for-in、for用法區(qū)別
- Javascript中的for in循環(huán)和hasOwnProperty結(jié)合使用
- JavaScript的遞歸之遞歸與循環(huán)示例介紹
- JavaScript中for..in循環(huán)陷阱介紹
- javascript中的循環(huán)語句for語句深入理解
- javascript閉包傳參和事件的循環(huán)綁定示例探討
- JavaScript中對循環(huán)語句的優(yōu)化技巧深入探討
- javascript實(shí)現(xiàn)圖片循環(huán)漸顯播放的方法
- 簡單學(xué)習(xí)JavaScript中的for語句循環(huán)結(jié)構(gòu)
- JavaScript中利用各種循環(huán)進(jìn)行遍歷的方式總結(jié)
- 跟我學(xué)習(xí)javascript的for循環(huán)和for...in循環(huán)
- 跟我學(xué)習(xí)javascript的循環(huán)
相關(guān)文章
js中flexible.js實(shí)現(xiàn)淘寶彈性布局方案
這篇文章主要為大家詳細(xì)介紹了js中flexible.js實(shí)現(xiàn)淘寶彈性布局方案,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-12-12一文讓你徹底搞清楚javascript中的require、import與export
這篇文章主要給大家介紹了關(guān)于javascript中require、import與export的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對打擊大的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09JS實(shí)現(xiàn)的自定義網(wǎng)頁拖動(dòng)類
這篇文章主要介紹了JS實(shí)現(xiàn)的自定義網(wǎng)頁拖動(dòng)類,涉及頁面元素響應(yīng)鼠標(biāo)事件動(dòng)態(tài)改變屬性的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-11-11JavaScript學(xué)習(xí)總結(jié)之JS、AJAX應(yīng)用
這篇文章主要介紹了JavaScript學(xué)習(xí)總結(jié)JS AJAX應(yīng)用 的相關(guān)資料,需要的朋友可以參考下2016-01-01layui實(shí)現(xiàn)登陸界面驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了layui實(shí)現(xiàn)登陸界面驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11javascript 面向?qū)ο骹unction詳解及實(shí)例代碼
這篇文章主要介紹了javascript 面向?qū)ο骹unction詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02layui中的tab控件點(diǎn)擊切換觸發(fā)事件
這篇文章主要介紹了layui中的tab控件點(diǎn)擊切換觸發(fā)事件,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06