JS实现多物体运动的方法详解


Posted in Javascript onJanuary 23, 2018

本文实例分析了JS实现多物体运动的方法。分享给大家供大家参考,具体如下:

基本步骤

1.通过getElementsByTagName获取到要做多物体运动的元素
2.然后for循环遍历元素,添加事件
3.定义startMove函数,需要两个参数,当前“做运动”的元素,和目标值target

注意问题:在多物体运动中,所有的东西不能公用;

<script>
    window.onload = function(){
      var liTags = document.getElementsByTagName('li'); // 第一步
      for(var i=0;i<liTags.length;i++){ // 第二步
         liTags[i].onmouseover = function () {
         startMove(this,400);
         }
         liTags[i].onmouseout = function () {
         startMove(this,200);
         }
      }
    }
    var timer = null;
    function startMove(obj,iTarget) { // 第三步,2个参数
      clearInterval(timer);
      timer = setInterval(function () {
        var iSpeed = (iTarget - obj.offsetWidth)/10;
        iSpeed = iSpeed>0 ?Math.ceil(iSpeed):Math.floor(iSpeed);// 缓冲运动注意取整处理
        if(obj.offsetWidth == iTarget){
          clearInterval(timer);
        }else{
          obj.style.width = obj.offsetWidth+iSpeed+'px';
        }
      },30);
    }
</script>

问题:

当移入移出速度比较快的时候,就会出现有的li回不到原来的样子,卡在半路了;这是因为所有的li公用了一个定时器造成的;

当鼠标移入第一个li时,调用startMove开启一个定时器;鼠标移除li时,也需要开启一个定时器让li回到原来的位置,li走到半路上,我们移入第二个li,首先会清除定时器,这时候第一个li就卡到半路了。

JS实现多物体运动的方法详解

解决这个问题:让每个li拥有自己的timer去控制他们的变化,在for循环的时候,给每个里定义自己的一个timer

liTags[i].timer = null;// 给每个li都添加一个timer

接着在starMove里面每次用的定时器都是当前li 自己的,就不会互相干扰了。

这里由之前的timer变成了obj.timer (当前对象自己的timer);到这里就没问题了。

完整代码如下:

<body>
<ul>
  <li></li>
  <li></li>
  <li></li>
  <li></li>
</ul>
</body>

加点样式:

<style>
    ul{list-style: none;}
    ul li{
      margin: 10px;
      width: 200px;height: 50px;
      background: lightblue;
    }
</style>

完整js代码

<script>
    window.onload = function(){
      var liTags = document.getElementsByTagName('li');
      for(var i=0;i<liTags.length;i++){
         liTags[i].timer = null;// 给每个li都添加一个timer
         liTags[i].onmouseover = function () {
         startMove(this,400);
         }
         liTags[i].onmouseout = function () {
         startMove(this,200);
         }
      }
    }
    function startMove(obj,iTarget) {
      clearInterval(obj.timer);
      obj.timer = setInterval(function () {
        var iSpeed = (iTarget - obj.offsetWidth)/10;
        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>

接着在看一个例子:多物体运动-改变透明度

<script>
  window.onload = function () {
    var aImgs = document.getElementsByTagName('img');
    for(var i=0;i<aImgs.length;i++){
      aImgs[i].timer = null;
      aImgs[i].alpha = 100; // 把公用的alpha改成每个img对象都有的属性
      aImgs[i].onmouseover = function () {
        startMove(this,30);
      }
      aImgs[i].onmouseout = function () {
        startMove(this,100);
      }
    }
  }
  // var alpha = 100; 这里alpha在多物体运动里 不能公用
  function startMove(obj,iTarget) {
    clearInterval(obj.timer);
    var iSpeed = (iTarget - obj.alpha)/10;
      iSpeed = iSpeed>0 ? Math.ceil(iSpeed): Math.floor(iSpeed);
    obj.timer = setInterval(function(){
      if(obj.alpha == iTarget){
        clearInterval(obj.timer);
      }else{
        obj.alpha += iSpeed;
        obj.style.opacity =obj.alpha/100;
        obj.style.filter = 'alpha(opacity:'+obj.alpha+')';
      }
    },30);
  }
</script>

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js实现网站首页图片滚动显示
Feb 04 Javascript
基于javascript实现浏览器滚动条快到底部时自动加载数据
Nov 30 Javascript
js中的关联数组与普通数组详解
Jul 27 Javascript
微信小程序 教程之事件
Oct 18 Javascript
jQuery简单自定义图片轮播插件及用法示例
Nov 21 Javascript
jQuery实现页面滚动时智能浮动定位
Jan 08 Javascript
基于JavaScript实现的快速排序算法分析
Apr 14 Javascript
利用canvas实现的加载动画效果实例代码
Jul 05 Javascript
详解express + mock让前后台并行开发
Jun 06 Javascript
微信小程序实现左侧滑栏过程解析
Aug 26 Javascript
Ajax获取node服务器数据的完整步骤
Sep 20 Javascript
js面向对象方式实现拖拽效果
Mar 03 Javascript
JS运动改变单物体透明度的方法分析
Jan 23 #Javascript
JS实现基于拖拽改变物体大小的方法
Jan 23 #Javascript
基于vue cli重构多页面脚手架过程详解
Jan 23 #Javascript
JS实现点击下拉菜单把选择的内容同步到input输入框内的实例
Jan 23 #Javascript
实时监控input框,实现输入框与下拉框联动的实例
Jan 23 #Javascript
从parcel.js打包出错到选择nvm的全部过程
Jan 23 #Javascript
浅谈vue项目重构技术要点和总结
Jan 23 #Javascript
You might like
PHP中,文件上传
2006/12/06 PHP
php反射应用示例
2014/02/25 PHP
windows平台中配置nginx+php环境
2015/12/06 PHP
ThinkPHP中limit()使用方法详解
2016/04/19 PHP
PHP实现非阻塞模式的方法分析
2018/07/26 PHP
discuz论坛更换域名,详细文件修改步骤
2020/12/09 PHP
12个非常有创意的JavaScript小游戏
2010/03/18 Javascript
jquery进行数组遍历如何跳出当前的each循环
2014/06/05 Javascript
Javascript实现网络监测的方法
2015/07/31 Javascript
聊一聊JavaScript作用域和作用域链
2016/05/03 Javascript
jQuery 获取多选框的值及多选框中文的函数
2016/05/16 Javascript
jQuery UI结合Ajax创建可定制的Web界面
2016/06/22 Javascript
前端面试知识点锦集(JavaScript篇)
2016/12/28 Javascript
vue2.0实现导航菜单切换效果
2017/05/08 Javascript
基于Vue.js实现tab滑块效果
2017/07/23 Javascript
利用Javascript获取选择文本所在的句子详解
2017/12/03 Javascript
JS实现简单获取最近7天和最近3天日期的方法
2018/04/18 Javascript
ES6新增的数组知识实例小结
2020/05/23 Javascript
node.js通过Sequelize 连接MySQL的方法
2020/12/28 Javascript
Python中绑定与未绑定的类方法用法分析
2016/04/29 Python
Python入门_浅谈逻辑判断与运算符
2017/05/16 Python
Django框架教程之正则表达式URL误区详解
2018/01/28 Python
Python找出微信上删除你好友的人脚本写法
2018/11/01 Python
常用python爬虫库介绍与简要说明
2020/01/25 Python
解决python -m pip install --upgrade pip 升级不成功问题
2020/03/05 Python
彻底弄明白CSS3的Media Queries(跨平台设计)
2010/07/27 HTML / CSS
百丽国际旗下购物网站:优购
2017/02/28 全球购物
网络工程师个人的自我评价范文
2013/10/01 职场文书
小学运动会入场式解说词
2014/02/18 职场文书
《猴子种果树》教学反思
2014/04/26 职场文书
法律系毕业生求职信
2014/05/28 职场文书
洗手间标语
2014/06/23 职场文书
民事申诉状范本
2015/05/20 职场文书
演讲开场白台词大全
2015/05/29 职场文书
严以律己专题学习研讨会发言材料
2015/11/09 职场文书
SQL Server 数据库实验课第五周——常用查询条件
2021/04/05 SQL Server