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

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

鼠標經過改變背景顏色問題

window.onload?=?function(){
???var?tableRows=document.getElementsByTagName("tr");
???for(var?i=0;i<tableRows.length;i++){
???????tableRows[i].onmouseover=function(){?
???????????tableRows[i].style.backgroundColor="yellow";
?????????}
?????????tableRows[i].onmouseout=function(){
?????????????tableRows[i].style.backgroundColor="#CCC";
??????????}
?????}
??}

為什么這種設置顏色時,總對初始那兩行報Cannot read property 'style' of undefined錯誤,然后只在新增加一行的上面生效。然后我改成圖片那種就沒有問題了。我感覺這是差不多的啊。

https://img1.sycdn.imooc.com//5bf4ca0b0001605205440306.jpg

我的添加代碼:

https://img1.sycdn.imooc.com//5bf4cae20001fef206190377.jpg


正在回答

3 回答

?tableRows[i].style.backgroundColor="yellow";

?tableRows[i].style.backgroundColor="#CCC";

你把你的這兩行代碼改成 :this.style.backgroundColor="yellow";this.style.backgroundColor="#CCC";

0 回復 有任何疑惑可以回復我~
#1

HYDMonster 提問者

謝謝哦,這樣就沒有問題了,你知道是為什么嗎
2018-11-21 回復 有任何疑惑可以回復我~

for循環時用var定義存在變量提升問題,tableRows[i].onmouseover=function(){tableRows[i].style.backgroundColor="yellow";};當執行移入移除的時候i已經循環到tableRows.length;所以只能是最后一個有效果吧。將tableRows[i]改為this時有效果是因為,this指向的是調用這個方法的對象,tableRows[i].onmouseover=function(){this.style.backgroundColor="yellow";};this指向的就是tableRows[i]。

我覺得是這個樣子,僅供參考

0 回復 有任何疑惑可以回復我~
#1

HYDMonster 提問者

謝謝哦
2018-11-29 回復 有任何疑惑可以回復我~

函數之間存在作用域,具體原理與理論我不太清楚去了.. 大概意思就是tableRows[i]是局部的。。不是全局

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

鼠標經過改變背景顏色問題

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

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

幫助反饋 APP下載

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

公眾號

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