原生js实现jquery函数animate()动画效果的简单实例


Posted in Javascript onAugust 21, 2016

通过在公司一个月的实习,慢慢的对css跟html算是比较熟悉了,这几天开始研究js,今天用js写了一个jquery的animate函数,测试了下,性能还可以。个人觉得jquery并不是万能的,因为是个框架,所以有些东西写的比较死,就像animate函数一样,可选的参数不多有时候可能并不能实现我们想要的效果。


注释的部分是用来测试用的,写代码的过程并不是十分顺利,因为用js平时用的不是很细,都是大体知道方法,也用过,但等到真正要实现动画函数的时候,细枝末节写错了就可能把人难住了。

函数里面有几个参数解释一下,

•obj, 函数的对象

•json, 数值对,形式{attr:”value”, attr: “value”},在这里是指要动画对象的运动属性

•interval, 每执行一次改变的间隔,这里改变的是对象是属性值

•sp, 值变换的速度,使动画具有缓冲效果,而不只是匀速不变(sp为1)的

•fn, 回调函数,执行完动画之后的行为

代码比较简单,只是有几个细节需要注意,在这里提醒一下:

•对象的属性不必直接声明,所以函数的第一句clearInterval(obj.timer);并不会报错。

•必须为每一个对象分别添加一个定时器,否则互相会影响,一个定时器公用的结果是定时器的多个对象运动出现卡顿。

•son数据格式了解一下,当遍历对象的动画属性的时候,需要icur != json[arr]判断是否每一个属性已经达到目标值。flag的作用是防止当其中某个属性第一个达到目标值后,clearInterval(obj.timer)清除了定时器,结果其他动画属性并没有达到目标值。所以在每次遍历的时候初始化flag值为true,只要遇到一个没有达到目标属性的对象,就将flag置为false,直至对象的所有属性达到目标值,清除定时器。

•speed = speed > 0 ? Math.ceil(speed): Math.floor(speed);

这一句的作用是将属性值取整,因为属性值除了opacity没有小数。

•最后调用的时候注意动画的对象,在使用for循环的时候不能随意使用arr[i]形式,尤其是嵌套循环的时候i的值已经变成了最大值。

js

function animate(obj, json, interval, sp, fn) {
  clearInterval(obj.timer);
  //var k = 0;
  //var j = 0;
  function getStyle(obj, arr) {
    if(obj.currentStyle){
      return obj.currentStyle[arr];  //针对ie
    } else {
      return document.defaultView.getComputedStyle(obj, null)[arr]; 
    }
  }
  obj.timer = setInterval(function(){
    //j ++;
    var flag = true;
    for(var arr in json) {
      var icur = 0;
      //k++;
      if(arr == "opacity") {
        icur = Math.round(parseFloat(getStyle(obj, arr))*100);
      } else {
        icur = parseInt(getStyle(obj, arr));
      }
      var speed = (json[arr] - icur) * sp;
      speed = speed > 0 ? Math.ceil(speed): Math.floor(speed);
      if(icur != json[arr]){
        flag = false;
      } 
      if(arr == "opacity"){
        obj.style.filter = "alpha(opacity : '+(icur + speed)+' )";
        obj.style.opacity = (icur + speed)/100;
      }else {
        obj.style[arr] = icur + speed + "px";
      }
      //console.log(j + "," + arr +":"+ flag);
    }

    if(flag){
      clearInterval(obj.timer);
      //console.log(j + ":" + flag); 
      //console.log("k = " + k);
      //console.log("j = " + j);
      //console.log("DONE");
      if(fn){
        fn();
      }
    }
  },interval);
}

调用方式:

<script>
  var move = document.getElementById("move").getElementsByTagName("li");
  for(var i = 0; i < move.length; i ++){
    move[i].onmouseover = function(){
      var _this = this;
      animate(_this, {width: 500, height: 200},10, 0.01, function(){
        animate(_this, {width: 300, height: 200},10, 0.01);
      });

    }
  }

</script>

以上这篇原生js实现jquery函数animate()动画效果的简单实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js表格分页实现代码
Sep 18 Javascript
director.js实现前端路由使用实例
Feb 03 Javascript
javascript的BOM汇总
Jul 16 Javascript
浏览器兼容的JS写法总结
Apr 27 Javascript
对Js OOP编程 创建对象的一些全面理解
Jul 26 Javascript
Vuejs 单文件组件实例详解
Feb 09 Javascript
解决vue+webpack打包路径的问题
Mar 06 Javascript
create-react-app构建项目慢的解决方法
Mar 14 Javascript
微信小程序 setData 对 data数据影响问题
Apr 18 Javascript
Vue+ElementUI项目使用webpack输出MPA的方法
Aug 27 Javascript
JavaScript实现飞舞的泡泡效果
Feb 07 Javascript
Vue Object.defineProperty及ProxyVue实现双向数据绑定
Sep 02 Javascript
原生JS实现图片轮播与淡入效果的简单实例
Aug 21 #Javascript
JavaScript实战(原生range和自定义特效)简单实例
Aug 21 #Javascript
原生JS实现-星级评分系统的简单实例
Aug 21 #Javascript
JSONP和批量操作功能的实现方法
Aug 21 #Javascript
全面解析标签页的切换方式
Aug 21 #Javascript
JavaScript第一篇之实现按钮全选、功能
Aug 21 #Javascript
JS实现图片局部放大或缩小的方法
Aug 20 #Javascript
You might like
PHP 开发环境配置(测试开发环境)
2010/04/28 PHP
PHP采集类Snoopy抓取图片实例
2014/06/19 PHP
完善CodeIgniter在IDE中代码提示功能的方法
2014/07/19 PHP
10款PHP开源商城系统汇总介绍
2015/07/23 PHP
php注册和登录界面的实现案例(推荐)
2016/10/24 PHP
php上传excel表格并获取数据
2017/04/27 PHP
PHP中ltrim()函数的用法与实例讲解
2019/03/28 PHP
用jQuery实现检测浏览器及版本的脚本代码
2008/01/22 Javascript
js 面向对象的技术创建高级 Web 应用程序
2010/02/25 Javascript
使用jQuery validate 验证注册表单实例演示
2013/03/25 Javascript
js中AppendChild与insertBefore的用法详细解析
2013/12/16 Javascript
Jquery对数组的操作技巧整理
2014/03/25 Javascript
Javascript封装DOMContentLoaded事件实例
2014/06/12 Javascript
浅谈JavaScript实现面向对象中的类
2014/12/09 Javascript
JavaScript动态修改背景颜色的方法
2015/04/16 Javascript
javascript检测flash插件是否被禁用的方法
2016/01/14 Javascript
TypeScript Type Innference(类型判断)
2016/03/10 Javascript
jQuery使用deferreds串行多个ajax请求
2016/08/22 Javascript
Vue+SpringBoot开发V部落博客管理平台
2017/12/27 Javascript
学习JS中的DOM节点以及操作
2018/04/30 Javascript
JavaScript中AOP的实现与应用
2019/05/06 Javascript
javascript操作向表格中动态加载数据
2020/08/27 Javascript
在Python中使用matplotlib模块绘制数据图的示例
2015/05/04 Python
使用py2exe在Windows下将Python程序转为exe文件
2016/03/04 Python
对Python3 序列解包详解
2019/02/16 Python
selenium如何定位span元素的实现
2021/01/13 Python
DJI美国:消费类无人机领域的领导者
2018/04/27 全球购物
澳大利亚一站式数码相机商店:CameraPro
2020/03/09 全球购物
Linux如何为某个操作添加别名
2015/02/05 面试题
我的中国梦演讲稿高中篇
2014/08/19 职场文书
推广活动策划方案
2014/08/23 职场文书
公司离职证明范本(5篇)
2014/09/17 职场文书
索赔员岗位职责
2015/02/15 职场文书
2015年实习生工作总结报告
2015/04/28 职场文书
学习焦裕禄观后感
2015/06/09 职场文书
2016年5月份红领巾广播稿
2015/12/21 职场文书