问答详情
源自:2-1 JS速度动画

请问哪里错了呢?为什么offsetleft=0的时候还不停呢?

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>无标题文档</title>

<script>

window.onload=function(){

var rtt=document.getElementById("tt");

rtt.onmouseover=function(){

startmove();

}

}


function startmove(){

var timer=null;

var rtt=document.getElementById("tt");

timer = setInterval(function(){

if(rtt.offsetLeft == 0){

clearInterval(timer);

}

else{

rtt.style.left=rtt.offsetLeft+10+"px"

}

},30)

}

</script>

</head>


<body>

<div id="tt" style="width: 500px; height: auto; position: absolute; left: -468px; top: 217px;"><img src="tt.jpg" style="width:500px"></div>


</body>

</html>


提问者:qq_Desperado_19 2016-08-21 16:23

个回答

  • 小菜鸟飞
    2016-08-21 16:53:29
    已采纳

    我觉得,因为他根本到不了0,,你的left是-468,一次加10,等到了-8的时候在加10,就是2,也不是0,就继续循环了,,你把left改成-460试试 ,应该就可以了


  • 小菜鸟飞
    2016-08-21 16:53:22

    我觉得,因为他根本到不了0,,你的left是-468,一次加10,等到了-8的时候在加10,就是2,也不是0,就继续循环了,,你把left改成-460试试 ,应该就可以了