缓动动画效果

缓动动画就是让元素运动速度有所变化,最常见的是让速度慢慢停下来。

思路:

1.让盒子每次移动的距离变小,速度就会慢慢落下来

2.核心算法:(目标值-现在的位置)/ 10 作为每次一定的距离 步长

3.停止的条件就是:让当前盒子位置等于目标位置就停止定时器

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style type="text/css">
			div {
				position: absolute;
				top: 50px;
				left: 0;
				width: 300px;
				height: 300px;
				background-color: skyblue;
			}
	
		</style>
	</head>
	<body>
		<button type="button">
			按下按钮开始
		</button>
		<div>
			
		</div>
		<script type="text/javascript">
			var div = document.querySelector('div');
			var btn = document.querySelector('button');
			function animate(obj, target) {
				clearInterval(obj.timer);
				obj.timer = setInterval(function() {
					if(obj.offsetLeft == target) {
						clearInterval(obj.timer);
					}
					obj.style.left = obj.offsetLeft + ((target - obj.offsetLeft) / 10) + 'px';
				},15);
				
			}
			
			btn.addEventListener('click',function() {
				animate(div,1000);
			})
			//匀速动画就是 盒子是当前的位置 +固定的值 10
			//缓动动画就是 盒子当前的位置 + 变化的值(目标值 - 现在的位置) / 10
		</script>
	</body>
</html>

缓动动画多个目标值之间移动:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style type="text/css">
			div {
				position: absolute;
				top: 50px;
				left: 0;
				width: 300px;
				height: 300px;
				background-color: skyblue;
			}
	
		</style>
	</head>
	<body>
		<button type="button" class="btn800">
			按下按钮开始移动到800
		</button>
		<button type="button" class="btn500">
			按下按钮开始移动到500
		</button>
		<div>
			
		</div>
		<script type="text/javascript">
			var div = document.querySelector('div');
			var btn500 = document.querySelector('.btn500');
			var btn800 = document.querySelector('.btn800');
			function animate(obj, target) {
				clearInterval(obj.timer);
				obj.timer = setInterval(function() {
					var step = (target - obj.offsetLeft) / 10;
					//这里在进位时 负数应该往小取 整数应该往大取
					step = step > 0 ? Math.ceil(step) : Math.floor(step);
					if(obj.offsetLeft == target) {
						clearInterval(obj.timer);
					}
					//这里会产生小数,所以最后移动到的并不是实际我们想要的位置,有一点小的偏差 因此在上边我们对其进行取整
					obj.style.left = obj.offsetLeft + step + 'px';
				},15);
				
			}
			
			btn500.addEventListener('click', function() {
				animate(div,500);
			});
			btn800.addEventListener('click', function() {
				animate(div,800);
			});
			//匀速动画就是 盒子是当前的位置 +固定的值 10
			//缓动动画就是 盒子当前的位置 + 变化的值(目标值 - 现在的位置) / 10
		</script>
	</body>
</html>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hcoke

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值