JavaScript实现多个物体同时运动


Posted in Javascript onMarch 12, 2020

本文实例为大家分享了JavaScript实现多个物体同时运动的具体代码,供大家参考,具体内容如下

1、多个物体同时运动

 ---例子:多个Div,鼠标移入变宽
  单定时器,存在问题
  每个Div一个定时器

2、多物体运动框架

定时器作为物体的属性
参数的传递:物体、目标值
    ---例子:多个Div淡入淡出
   所有东西都不能公用
   属性与运动对象绑定
:速度、其他属性值(如透明度等)

3、多个Div,鼠标移入变宽的例子

3.1 代码

<head>
 <meta charset="UTF-8">
 <title>多物体运动框架</title>
 <style type="text/css">
 div {
 width: 100px;
 height: 50px;
 background: red;
 margin-top: 50px;
 }
 </style>
 <script type="text/javascript">
 window.onload = function() {
  //获取元素
  var aDiv = document.getElementsByTagName("div");
  for (var i = 0; i < aDiv.length; i++) {
  aDiv[i].onmousemove = function() {
  startMove(this, 300);
  }
  aDiv[i].onmouseout = function() {
  startMove(this, 100);
  }
  }
 }
 //运动函数
 function startMove(obj, iTarget) {
 //清楚定时器函数
 //由于是是适应于多个对象的变化,所以每个DIV有一个定时器
 clearInterval(obj.timer);
 //定时器函数
 //每一个对象,有一个定时器
 obj.timer = setInterval(function() {
  //记录速度
  var iSpeed = (iTarget - obj.offsetWidth) / 5;
  iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);
  //运动和停止的判断条件
  if (obj.offsetWidth == iTarget) {
  //清楚定时器函数
  clearInterval(obj.timer);
  } else {
  obj.style.width = obj.offsetWidth + iSpeed + 'px';
  }
 }, 30);
 }
 </script>
 </head>
 
 <body>
 <div></div>
 <div></div>
 <div></div>
</body>

3.2 多个DIV淡入淡出的例子

<head>
 <meta charset="UTF-8">
 <title>多物体运动框架</title>
 <style type="text/css">
 div {
 width: 100px;
 height: 100px;
 background: red;
 margin-top: 50px;
 filter: alpha(opacity: 30);
 opacity: 0.3;
 }
 </style>
 <script type="text/javascript">
 window.onload = function() {
  //获取元素
  var aDiv = document.getElementsByTagName("div");
  for (var i = 0; i < aDiv.length; i++) {
  //将alpha作为,物体的一个属性
  aDiv[i].alpha = 30;
  aDiv[i].onmousemove = function() {
  startMove(this, 100);
  }
  aDiv[i].onmouseout = function() {
  startMove(this, 30);
  }
  }
 }
 //运动函数
 function startMove(obj, iTarget) {
 //清楚定时器函数
 clearInterval(obj.timer);
 //定时器函数
 obj.timer = setInterval(function() {
  //记录速度
  var iSpeed = (iTarget - obj.alpha) / 8;
  iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);
  //运动和停止的判断条件
  if (obj.alpha == iTarget) {
  //清楚定时器函数
  clearInterval(obj.timer);
  } else {
  obj.alpha += iSpeed;
  obj.style.filter = 'alpha(opacity:' + obj.alpha + ')';
  obj.style.opacity = obj.alpha / 100;
  }
 }, 30);
 }
 </script>
 </head>
 
 <body>
 <div></div>
 <div></div>
 <div></div>
 <div></div>
 
</body>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript禁用键盘功能键让右击及其他键无效
Oct 09 Javascript
JavaScript从数组的indexOf()深入之Object的Property机制
May 11 Javascript
javascript 删除数组元素和清空数组的简单方法
Feb 24 Javascript
微信小程序 合法域名校验出错详解及解决办法
Mar 09 Javascript
使用vue构建移动应用实战代码
Aug 02 Javascript
浅谈关于angularJs中使用$.ajax的注意点
Aug 12 Javascript
详解webpack之图片引入-增强的file-loader:url-loader
Oct 08 Javascript
JavaScript显式数据类型转换详解
Mar 18 Javascript
vue全局自定义指令-元素拖拽的实现代码
Apr 14 Javascript
vue路由中前进后退的一些事儿
May 18 Javascript
keep-alive保持组件状态的方法
Dec 02 Javascript
微信小程序input抖动问题的修复方法
Mar 03 Javascript
基于javascript实现碰撞检测
Mar 12 #Javascript
jQuery使用ajax传递json对象到服务端及contentType的用法示例
Mar 12 #jQuery
js 使用ajax设置和获取自定义header信息的方法小结
Mar 12 #Javascript
javascript实现拖拽碰撞检测
Mar 12 #Javascript
原生js实现碰撞检测
Mar 12 #Javascript
vue实现导航标题栏随页面滚动渐隐渐显效果
Mar 12 #Javascript
three.js利用射线Raycaster进行碰撞检测
Mar 12 #Javascript
You might like
php操作excel文件 基于phpexcel
2010/07/02 PHP
PHP 观察者模式的实现代码
2013/05/10 PHP
在Mac OS上自行编译安装Apache服务器和PHP解释器
2015/12/24 PHP
JSON字符串传到后台PHP处理问题的解决方法
2016/06/05 PHP
php变量与数组相互转换的方法(extract与compact)
2016/12/02 PHP
thinkphp框架page类与bootstrap分页(美化)
2017/06/25 PHP
Js 获取当前日期时间及其它操作实现代码
2021/03/04 Javascript
在html页面上拖放移动标签
2010/01/08 Javascript
文本框根据输入内容自适应高度的代码
2011/10/24 Javascript
文本框输入时 实现自动提示(像百度、google一样)
2012/04/05 Javascript
jquery 实现表单验证功能代码(简洁)
2012/07/03 Javascript
浅析js封装和作用域
2013/07/09 Javascript
js中如何把字符串转化为对象、数组示例代码
2013/07/17 Javascript
js使用for循环及if语句判断多个一样的name
2014/09/09 Javascript
JS实现网页标题随机显示名人名言的方法
2015/11/03 Javascript
解决JS无法调用Controller问题的方法
2015/12/31 Javascript
JavaScript实现iframe自动高度调整和不同主域名跨域
2016/02/27 Javascript
微信小程序 request接口的封装实例代码
2017/04/26 Javascript
Angularjs中使用轮播图指令swiper
2017/05/30 Javascript
详解基于node的前端项目编译时内存溢出问题
2017/08/01 Javascript
javascript实现导航栏分页效果
2019/06/27 Javascript
JavaScript回调函数callback用法解析
2020/01/14 Javascript
[46:28]EG vs Liquid 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.23
2019/09/05 DOTA
Python带动态参数功能的sqlite工具类
2018/05/26 Python
django利用request id便于定位及给日志加上request_id
2018/08/26 Python
在Python 不同级目录之间模块的调用方法
2019/01/19 Python
python 直接赋值和copy的区别详解
2019/08/07 Python
Pandas时间序列重采样(resample)方法中closed、label的作用详解
2019/12/10 Python
Python unittest生成测试报告过程解析
2020/09/08 Python
沙龙级头发造型工具:FOXYBAE
2018/07/01 全球购物
党员年终民主评议的自我评价
2013/11/05 职场文书
航空大学应届生求职信
2013/11/10 职场文书
小学门卫岗位职责
2013/12/17 职场文书
向领导表决心的话
2014/03/11 职场文书
读书月活动方案
2014/05/22 职场文书
个人校本研修方案
2014/05/26 职场文书