如果浏览器不支持小数像素,var speed = (iTarget - oDiv.offsetLeft)/20;当speed等于20以下的时候,oDiv.style.left = oDiv.offsetLeft + speed +'px';这里的speed就小于1了。浏览器应该在20px左右的时候就停止了,为什么是在10px左右的时候停止呢

来源:3-1 JS缓冲动画

慕斯7571954

2016-09-19 18:09

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8">

<title></title>

<style type="text/css">

body,div,span{

margin: 0;

padding: 0;

}

   #div1{

    width: 200px;

    height: 200px;

    left: -200px;

    background-color: red;

    position: relative;

   }

#div1 span{

width: 20px;

height: 50px;

background-color: blue;

position: absolute;

top:75px;

left: 200px;

}

</style>

<script type="text/javascript">

window.onload = function(){

var oDiv = document.getElementById('div1');

oDiv.onmouseover = function () {

startMove(0);

}

oDiv.onmouseout = function () {

startMove(-200);

}

}


var timer = null;

function startMove(iTarget) {

clearInterval(timer);

var oDiv = document.getElementById('div1');

timer = setInterval(function () {

var speed = (iTarget - oDiv.offsetLeft)/20;

if (oDiv.offsetLeft == iTarget) {

clearInterval(timer);

} else {

oDiv.style.left = oDiv.offsetLeft + speed +'px';

}

},30)

}

</script>

</head>

<body>

<div id="div1">

<span id="share">分享</span>

</div>

</body>

</html>

如果浏览器不支持小数像素,var speed = (iTarget - oDiv.offsetLeft)/20;当speed等于20以下的时候,oDiv.style.left = oDiv.offsetLeft + speed +'px';这里的speed就小于1了。浏览器应该在20px左右的时候就停止了,为什么是在10px左右的时候停止呢

写回答 关注

2回答

  • 慕粉3771545
    2016-09-19 21:46:53
    已采纳

    我猜是因为像素有小数时会四舍五入,所以speed小于1大于0.5时还会动,10px左右的时候停止是刚好speed在0.5的分界线

    慕斯7571...

    非常感谢!

    2016-09-20 11:29:44

    共 1 条回复 >

  • 重九译
    2016-09-19 21:46:11

    看教程

JS动画效果

通过本课程JS动画的学习,从简单动画开始,逐步深入各种动画框架封装

113925 学习 · 1443 问题

查看课程

相似问题