缓冲运动

<!DOCTYPE html>

<html>


<head>

<meta charset="UTF-8">

<title></title>

<style type="text/css">

#div1 {

width: 100px;

height: 100px;

background-color: red;

position: absolute;

top: 50px;

/*left: 0;*/

left: 600px;

}

#div2{

width: 1px;

height: 300px;

background-color: black;

position: absolute;

top: 0;

left: 300px;

}

</style>

</head>


<body>

<input type="button" name="btn1" id="btn1" value="开始运动" />

<div id="div1"></div>

<div id="div2"></div>

<script type="text/javascript">

var oBtn = document.getElementById("btn1");

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

oBtn.onclick = function() {

startMove();

};


// 缓冲运动

// 先快后慢

// 距离越大速度越快,距离越小速度越慢(距离和速度成正比)


var timer = null;


function startMove() {

clearInterval(timer);

timer = setInterval(function() {

var speed = (300 - oDiv.offsetLeft) / 10;

// 如果大于0,向上取整,如果小于0,向下取整

speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);

if (oDiv.offsetLeft == 300) {

clearInterval(timer);

} else {

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

}

document.title = oDiv.offsetLeft + "," + speed;

}, 20);

}

</script>

</body>


</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值