亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

循環遍歷為什么需要將 i 再記錄一遍?

循環遍歷為什么需要將 i 再記錄一遍?

FFIVE 2018-09-04 09:25:45
js代碼如下:window.onload = function() {        var menu = document.getElementById('menu'),             ps = menu.getElementsByTagName('p'),             uls = menu.getElementsByTagName('ul');        for (var i = 0; i < ps.length; i++) {             ps[i].id = i;  //為什么這里需要將 i 再記錄一遍?             ps[i].onclick = function() {                 uls[this.id].style.display = "block"; //這里直接寫usl[i].style.display="block" 為什么不行?它們不是同一個i嗎?             };         }     };html代碼如下:<div class="menu" id="menu">    <div>        <p>Web前端</p>        <ul style="display:block">            <li>JavaScript</li>            <li>DIV+CSS</li>            <li>jQuery</li>        </ul>    </div>    <div>        <p>后臺腳本</p>        <ul>            <li>PHP</li>            <li>ASP.net</li>            <li>JSP</li>        </ul>    </div>    <div>        <p>前端框架</p>        <ul>            <li>Extjs</li>            <li>Esspress</li>            <li>YUI</li>        </ul>    </div> </div>
查看完整描述

1 回答

?
慕田峪4524236

TA貢獻1875條經驗 獲得超5個贊

因為onClick不是立即執行的,實際上當事件處理函數執行時,這里如果使用i的話會引用同一個i,而且這個i值等于for循環結束時i的值。

實際上這里起的效果跟閉包是一樣的,具體效果是讓每一個事件處理函數都有屬于它自身的i值,而不是引用同一個i。


查看完整回答
反對 回復 2018-10-20
  • 1 回答
  • 0 關注
  • 491 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號