JS运动带有缓冲运动的悬浮框

JS运动应用悬浮框的制作,在一些网站中我们会发现有一种出现在右下方的广告栏,它会随着拖动条的移动来移动,下面就是小编写的关于这个东西制作的原理图

小编在这里将先告诉大家缓冲运动的理念,然后我们在制作悬浮框的时候可能经常会出现悬浮框一闪一闪卡顿的情况,我们如果利用缓冲运动就可以轻松解决这样闪的问题。下面的代码是缓冲运动的原理

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8"> 
		<title>缓冲运动</title>
		<style type="text/css">
		/*向左移动的css*/
			#div1{width: 100px; height: 100px; background: red; position: absolute;left: 600px; top: 50px;}
			/*#div1{width: 100px; height: 100px; background: red; position: absolute;left: 0px; top: 50px;}向有移动的css*/
			#div2{width: 1px; height: 300px; left: 300px; top: 0px; background: black; position: absolute;}
			/*会发现div1差了一块并没有到达300像素因为走到最后speed变为零点几,像素不可能变为小数,299.9px计算机会认为是299px*/
		</style>
		<script>
			function startMove() {
				var oDiv = document.getElementById('div1');
				
				setInterval(function () {
					var speed = (300 - oDiv.offsetLeft)/10;
					
//					speed = Math.ceil(speed);//根据上面的注释所以这里应该采用向上取整
					//但是如果div向左移动呢?应该想到用floor
					//根据上面的注释说明可以这样改
					speed = speed>0?Math.ceil(speed):Math.floor(speed);
					oDiv.style.left = oDiv.offsetLeft + speed + 'px';
				},30)
			}
		</script>
	</head>
	<body>
		<input type="button"  value="开始运动" onclick="startMove()"/>
		<div id="div1">	</div>
		<div id="div2"></div>
		<!--div2作为一个标杆-->
	</body>
</html>

在这里插入图片描述
下面是带有缓冲运动悬浮框的代码

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>悬浮框</title>
		<style type="text/css">
			#div1{width: 100px; height: 150px; background: lightslategray; position: absolute;right: 0; bottom: 0;}
		</style>
		<script type="text/javascript">
			window.onscroll=function () {
				var oDiv = document.getElementById('div1');
				var scrollTop = document.documentElement.scrollTop||document.body.scrollTop;
				
//				oDiv.style.top = document.documentElement.clientHeight - oDiv.offsetHeight+scrollTop + 'px';这是在未使用缓冲运动的框架
//使用缓冲运动的框架后
                startMove(document.documentElement.clientHeight - oDiv.offsetHeight+scrollTop);
			}
			
			var timer = null;
			
			function startMove(iTarget) {
				var oDiv = document.getElementById('div1');
				
				clearInterval(timer);
				timer = setInterval(function () {
					var speed = (iTarget - oDiv.offsetTop)/4;
					speed = speed>0?Math.ceil(speed):Math.floor(speed);
					
					if(oDiv.offsetTop == iTarget){
						clearInterval(timer);
					}else{
						oDiv.style.top = oDiv.offsetTop + speed + 'px';
					}
					
				},30)
				
			}
		</script>
	</head>
	<body style="height: 2000px;">
		<div id="div1">
			
		</div>
	</body>
</html>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值