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 相关文章推荐
jquery入门—访问DOM对象方法
Jan 07 Javascript
简单实例处理url特殊符号&amp;处理(2种方法)
Apr 02 Javascript
三种方式获取XMLHttpRequest对象
Apr 21 Javascript
Jquery 获取指定标签的对象及属性的设置与移除
May 29 Javascript
JS实现的表格行鼠标点击高亮效果代码
Nov 27 Javascript
JS实现DIV容器赋值的方法
Dec 14 Javascript
webpack开发跨域问题解决办法
Aug 03 Javascript
在Vue项目中引入腾讯验证码服务的教程
Apr 03 Javascript
微信小程序出现wx.getLocation再次授权问题的解决方法分析
Jan 16 Javascript
详解VUE调用本地json的使用方法
May 15 Javascript
浅谈JavaScript窗体Window.ShowModalDialog使用
Jul 22 Javascript
vue3中轻松实现switch功能组件的全过程
Jan 07 Vue.js
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/10/09 PHP
PHP 判断变量类型实现代码
2009/10/23 PHP
php设计模式 Interpreter(解释器模式)
2011/06/26 PHP
PHP入门教程之面向对象基本概念实例分析
2016/09/11 PHP
解决在Laravel 中处理OPTIONS请求的问题
2019/10/11 PHP
用js自动判断浏览器分辨率的代码
2007/01/28 Javascript
javascript web对话框与弹出窗口
2009/02/22 Javascript
[推荐]javascript 面向对象技术基础教程
2009/03/03 Javascript
Node.js实战 建立简单的Web服务器
2012/03/08 Javascript
Javascript自定义函数判断网站访问类型是PC还是移动终端
2014/01/10 Javascript
JQuery动态添加Select的Option元素实现方法
2016/08/29 Javascript
js实现表单提交后不重新刷新当前页面
2016/11/30 Javascript
原生JS实现在线问卷调查投票特效
2017/01/03 Javascript
AugularJS从入门到实践(必看篇)
2017/07/10 Javascript
基于ES6作用域和解构赋值详解
2017/11/03 Javascript
javascript按顺序加载运行js方法
2017/12/01 Javascript
Vue2.0 实现单选互斥的方法
2018/04/13 Javascript
Vue中import from的来源及省略后缀与加载文件夹问题
2020/02/09 Javascript
VUE中V-IF条件判断改变元素的样式操作
2020/08/09 Javascript
js实现计算器功能
2020/08/10 Javascript
python字典排序实例详解
2015/05/20 Python
Python实现以时间换空间的缓存替换算法
2016/02/19 Python
python Matplotlib画图之调整字体大小的示例
2017/11/20 Python
Python3之简单搭建自带服务器的实例讲解
2018/06/04 Python
python爬取足球直播吧五大联赛积分榜
2018/06/13 Python
Python中的延迟绑定原理详解
2019/10/11 Python
将pymysql获取到的数据类型是tuple转化为pandas方式
2020/05/15 Python
关于keras中keras.layers.merge的用法说明
2020/05/23 Python
CSS3 对过渡(transition)进行调速以及延时
2020/10/21 HTML / CSS
Clarks英国官方网站:全球领军鞋履品牌
2016/11/26 全球购物
我们的节日清明节活动总结
2014/04/30 职场文书
党员批评与自我批评发言稿
2014/10/14 职场文书
今日说法观后感
2015/06/08 职场文书
在Windows下安装配置CPU版的PyTorch的方法
2021/04/02 Python
Vite + React从零开始搭建一个开源组件库
2022/06/25 Javascript
浅谈css清除浮动(clearfix和clear)的用法
2023/05/21 HTML / CSS