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

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

一個原生js的新手問題--和this有點關系

一個原生js的新手問題--和this有點關系

肖小波 2016-12-08 19:34:48
<!DOCTYPE html><html>?? ?<head>?? ??? ?<meta charset="UTF-8">?? ??? ?<title></title>?? ??? ?<style>?? ??? ??? ?ul{?? ??? ??? ??? ?position: relative;?? ??? ??? ??? ?list-style: none;?? ??? ??? ?}?? ??? ??? ?ul li{?? ??? ??? ??? ?width: 100px;?? ??? ??? ??? ?height: 50px;?? ??? ??? ??? ?background: #CCCCCC;?? ??? ??? ??? ?margin: 2px;?? ??? ??? ?}?? ??? ??? ?div{?? ??? ??? ??? ?width: 200px;?? ??? ??? ??? ?height: 200px;?? ??? ??? ??? ?background: greenyellow;?? ??? ??? ??? ?position: absolute;?? ??? ??? ??? ?top: 0px;?? ??? ??? ??? ?left: 150px;?? ??? ??? ??? ?display: block;?? ??? ??? ?}?? ??? ?</style>?? ??? ?<script>?? ??? ??? ?window.onload=function(){?? ??? ??? ??? ?var oUl=document.getElementsByTagName("ul")[0];?? ??? ??? ??? ?var oLi=document.getElementsByTagName("li");?? ??? ??? ??? ?var oDiv=document.getElementsByTagName("div")[0];?? ??? ??? ??? ?for (var i=0;i<oLi.length;i++) {?? ??? ??? ??? ??? ?oLi[i].onmousemove=function(){?? ??? ??? ??? ??? ??? ?if (oUl.offsetHeight-oLi[i].offsetTop>200) {?? ??? ??? ??? ??? ??? ??? ?oDiv.style.top=oLi[i].offsetTop+"px";?? ??? ??? ??? ??? ??? ??? ?oDiv.style.display="block";?? ??? ??? ??? ??? ??? ?}?? ??? ??? ??? ??? ??? ?else{?? ??? ??? ??? ??? ??? ??? ?oDiv.style.top=this.offsetTop+oLi[i].offsetHeight-200+"px";?? ??? ??? ??? ??? ??? ?}?? ??? ??? ??? ??? ??? ??? ??? ??? ??? ?}?? ??? ??? ??? ?}?? ??? ??? ?}?? ??? ?</script>?? ?</head>?? ?<body>?? ??? ?<ul>?? ??? ??? ?<li>1111</li>?? ??? ??? ?<li>2222</li>?? ??? ??? ?<li>3333</li>?? ??? ??? ?<li>4444</li>?? ??? ??? ?<li>5555</li>?? ??? ??? ?<li>6666</li>?? ??? ??? ?<li>7777</li>?? ??? ??? ?<li>8888</li>?? ??? ??? ?<li>9999</li>?? ??? ??? ?<li>1010</li>?? ??? ??? ?<div></div>?? ??? ?</ul>?? ?</body></html>這個程序運行為什么會報錯---Cannot read property 'offsetTop' of undefined"?但是把oLi【i】改成this反而可以運行為什么會這樣
查看完整描述

1 回答

?
冥oo冥

TA貢獻8條經驗 獲得超1個贊

用this吧

簡單的說,

for(var i=0;i<10;i++){

a.onmouseover = b;

}

function b(){

//這兒不識別i

}


查看完整回答
反對 回復 2016-12-08
  • 肖小波
    肖小波
    謝謝回答,測試后發現i是可以識別的,只是i=10。
  • 1 回答
  • 0 關注
  • 1692 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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