点滴积累【JS】---JS小功能(JS实现多物体缓冲运动)
2024-08-27 16:15:45
效果:
思路:
利用setInterval计时器进行运动,offsetWidth实现宽度的变动,在用onmouseover将终点和所选中的DIV放入参数再进行缓冲运动。
代码:
<head runat="server">
<title></title>
<style type="text/css">
div
{
width: 100px;
height: 50px;
background: #0000FF;
margin: 10px;
}
</style>
<script type="text/javascript">
window.onload = function () {
var oDiv = document.getElementsByTagName('div');
for (var i = 0; i < oDiv.length; i++) {
oDiv[i].timer = null; //给买个DIV做个标记,用以关闭相应DIV的定时器
oDiv[i].onmouseover = function () {
move(this, 400); //给定时器输出参数
}
oDiv[i].onmouseout = function () {
move(this, 100);
}
}
};
function move(div, end) {
clearInterval(div.timer);
div.timer = setInterval(function () {
var speed = (end - div.offsetWidth) / 5; //(终点-要走的宽度)/缩放系数=DIV移动的速度
speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed); //小数取整,也就是进位取整
if (div.offsetWidth == end) { //当到达终点时关闭计时器
clearInterval(div.timer);
}
else {
div.style.width = div.offsetWidth + speed + 'px'; //移动DIV的宽度
}
}, 30)
}
</script>
</head>
<body>
<div>
</div>
<div>
</div>
<div>
</div>
</body>
最新文章
- 基于Kubernetes在AWS上部署Kafka时遇到的一些问题
- 国内2大Git代码托管网站
- XCTest各种断言
- JMeter学习-034-JMeter调试工具之一---HTTP Mirror Server
- The constructor BASE64Encoder() is not accessible due to restriction on required library
- Python开发【第五章】:Python常用模块
- 感冒了~ vs中py和vb实现一个小算法
- 转:画图解释 SQL join 语句
- 小明A+B[HDU2096]
- 理解Linux系统中的load average(图文版)转
- Ignatius and the Princess III
- ip,子网掩码,网关,DNS
- c++ primer plus 习题答案(7)
- Listview的OnScrollListener的滑动监听实现分页加载
- 路由器安装ubuntu-16.04.1-server-amd64出现“无法安装busybox-initramfs”错误。向目标系统中安装busybox-initramfs软件包时出现一个错误。请检查/var/log/syslog或查看第四虚拟控制台以获得详细
- 编译问题解决:LINK : fatal error LNK1104: 无法打开文件“*.dll”
- spring-data-mongodb与mongo shell的对应关系
- 命名空间 extern的用法 static全局变量
- python语法基础笔记
- UOJ #146. 【NOIP2015】信息传递 连通分量 tarjan模板题