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

為了賬號安全,請及時綁定郵箱和手機立即綁定

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只是個引用,循環結束后i的值就變了,你可以試試每次輸出的i都死i.length.在js中for是無作用域的。執行dom節點操作時取得便是for最后的i++的值.這是JavaScript一個經典問題:在遍歷數組時對DOM監聽事件,索引值始終等于遍歷結束后的值.

解決方法:

方法一:利用必包

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節點添加_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 回復 有任何疑惑可以回復我~
#1

召喚師 提問者

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

舉報

0/150
提交
取消

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

我要回答 關注問題
微信客服

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

幫助反饋 APP下載

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

公眾號

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