第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

js中變量的作用域是怎么一回事?

as=box.getElementsByTagName('a');

for(var i=0; i<as.length; i++) {
??????? as[i].onmouseover = function() {
??????????? this.style.background = '#D0D6D9';
??????? }
??????? as[i].onmouseout = function() {
??????????? this.style.background = '#FFF';
??????? }
??????? as[i].onclick = function() {
??????????? title.innerHTML = this.innerHTML;
??????? }
??? }

上段代碼中,使用this.style可以而使用as[i].style為什么不可以???

正在回答

1 回答

你綁定事件是i只是個(gè)引用,循環(huán)結(jié)束后i的值就變了,你可以試試每次輸出的i都死i.length.在js中for是無(wú)作用域的。執(zhí)行dom節(jié)點(diǎn)操作時(shí)取得便是for最后的i++的值.這是JavaScript一個(gè)經(jīng)典問(wèn)題:在遍歷數(shù)組時(shí)對(duì)DOM監(jiān)聽(tīng)事件,索引值始終等于遍歷結(jié)束后的值.

解決方法:

方法一:利用必包

for(var i=0;i<as.length;i++){

? ? (function (_i){

? ? ?as[_i].onmouseover = function() {
??????????? this.style.background = '#D0D6D9';
??????? }
??????? as[_i].onmouseout = function() {
??????????? this.style.background = '#FFF';
??????? }
??????? as[_i].onclick = function() {
??????????? title.innerHTML = this.innerHTML;
??????? }

})(i);

}

方法二:給DOM節(jié)點(diǎn)添加_index屬性,屬性值等于索引

for(var?i=0;i<as.length;i++){

????as[i]._index=i;

????as[i].onclick=function(){

????????as[i].onmouseover = function() {
??????????? this.style.background = '#D0D6D9';
??????? }
??????? as[i].onmouseout = function() {
??????????? this.style.background = '#FFF';
??????? }
??????? as[i].onclick = function() {
??????????? title.innerHTML = this.innerHTML;
??????? }

????}

}??


3 回復(fù) 有任何疑惑可以回復(fù)我~
#1

召喚師 提問(wèn)者

非常感謝你的回答?。?!
2016-04-19 回復(fù) 有任何疑惑可以回復(fù)我~

舉報(bào)

0/150
提交
取消
DOM事件探秘
  • 參與學(xué)習(xí)       99532    人
  • 解答問(wèn)題       1305    個(gè)

DOM事件?本課程會(huì)通過(guò)實(shí)例來(lái)給小伙伴們講解如何使用這些事件

進(jìn)入課程

js中變量的作用域是怎么一回事?

我要回答 關(guān)注問(wèn)題
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)