JavaScript缓动动画函数的封装方法


Posted in Javascript onNovember 25, 2020

本文实例为大家分享了JavaScript缓动动画函数的封装代码,供大家参考,具体内容如下

本文将从封装缓动动画的以下几个部分进行封装(1、单个属性,2、多个属性,3、缓动框架之回调函数,4、缓动框架之层级与透明度)

首先:获取元素样式的兼容方式

function getStyle(ele,attr){      //获取任意类型的CSS样式的属性值
  if(window.getComputedStyle){    
    return window.getComputedStyle(ele,null)[attr];
  }
  return ele.currentStyle[attr];
}

封装单个属性

function animate(ele,attr,target){   //元素(box) 样式(left) 目标值(400)
  clearInterval(ele.timer);     //使用定时器时,先清除定时器,防止多个定时器并行
  ele.timer = setInterval(function(){
    //先定义一个当前值
    var leader = parseInt(getStyle(ele,attr)) || 0;   //当这个样式为空时设置为0,获取来的样式值要取整。
    var step = (target - leader)/10;
    step = step > 0 ? Math.ceil(step) : Math.floor(step);
    leader = leader + step;
    ele.style[attr] = leader + "px";     //注意设置元素样式,注意加单位
    if(Math.abs(target-leader) <= Math.abs(step)){
      ele.style[attr] = target + "px";
      clearInterval(ele.timer);
    }
  },25);
}

封装多个属性

function animate(ele,json){   //把样式和目标值放在json中,如:var json = {"left":10,"top":200,"width":300,"height":200}  
  clearInterval(ele.timer);
  ele.timer = setInterval(function(){
    //开闭原则,目的保证所有样式都到达目标值
    var bool = true;
    // 分别单独处理json;
    for(k in json){
      var attr = k;  //这里的k即上文中的样式
      var target = json[k];  //这里的json[k]即上文中的目标值,熟练后直接写k,json[k]。
      var leader = parseInt(getStyle(ele,attr)) || 0;
      var step = (target - leader) / 10;
      step = step > 0 ? Math.ceil(step) : Math.floor(step);
      leader = leader + step;
      ele.style[attr] = leader + "px";

      //如果使用上文中清除定时器的方式,则完成了一个json内容就清除了定时器,显然不能这么做
      // if(Math.abs(target - leader) <= Math.abs(step)){
        // ele.style[attr] = target + "px";
        // clearInterval(ele.timer);
      // }
      if(target !== leader){  //依据上文定义的bool,遍历json时当有一个样式未完成,则bool值依旧为false。
        bool = false;
      }
    }

    //只有所有属性样式都到了指定位置,bool值才变成true
    if(bool){  
      clearInterval(ele.timer);
    }
  },25);       
}

缓动框架之回调函数

function animate(ele,json,fn){
    clearInterval(ele.timer);
    ele.timer = setInterval(function(){
        var bool = true;
        for(k in json){       
            var leader = parseInt(getStyle(ele,k)) || 0;  
            var step = (json[k] - leader) / 10;
            step = step > 0 ? Math.ceil(step) : Math.floor(step);
            leader = leader + step;
            ele.style[k] = leader + "px";
            if(json[k] !== leader){
                bool = false;
            }
        }
        if(bool){
            clearInterval(ele.timer);
            if(fn){     //此处如果有函数,则掉用,如果没有则自动不执行,当然也可加个判断,if(typeof fn == "function"),当fn类型为函数时。
                fn();
            }
        }
    },25);
}

//调用
animate(box,json,function(){      //这里的function是一整个函数体,所以上文中的fn要加();
    animate(box,json1,function(){     //当执行完第一个缓动动画时,有function则继续执行。
        animate(box,json);
    });
});

缓动框架之层级与透明度

function animate(ele,json,fn){
  clearInterval(ele.timer);
  ele.timer = setInterval(function(){
    var bool = true;
    for(k in json){
      var leader;
      if(k === "opacity"){   //如果属性为opacity
        leader = getStyle(ele,k) * 100 || 1;  //不能取整,先把它乘100
      }else{
        leader = parseInt(getStyle(ele,k)) || 0;  
      }          
      var step = (json[k] - leader) / 10; 
      step = step > 0 ? Math.ceil(step) : Math.floor(step);
      leader = leader + step;
      if(k === "opacity"){ 
        ele.style[k] = leader/100;   //如果是opacity,赋值时在除以100
        ele.style.filter = "alpha(opacity="+leader+")";   //兼容IE
      }else if(k === "zIndex"){
        ele.style[k] = leader;   //直接赋值就是了,不用加单位
      }else{
        ele.style[k] = leader + "px";
      }
      if(json[k] !== leader){
        bool = false;
        console.log(leader);
      }
    }
    if(bool){
      clearInterval(ele.timer);
      if(fn){
        fn();
      }
    }
  },30);
}
**//注意这里赋值的opacity要乘以100,如:30,100等**

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

Javascript 相关文章推荐
[原创]网络复制内容时常用的正则+editplus
Nov 30 Javascript
ASP SQL防注入的方法
Dec 25 Javascript
js 利用className得到对象的实现代码
Nov 15 Javascript
JS检测页面中哪个HTML标签触发点击事件的方法
Jun 17 Javascript
基于jQuery实现歌词滚动版音乐播放器的代码
Sep 17 Javascript
jquery应用实例分享_实现手风琴特效
Feb 01 jQuery
vue+express 构建后台管理系统的示例代码
Jul 19 Javascript
用POSTMAN发送JSON格式的POST请求示例
Sep 04 Javascript
从零撸一个pc端vue的ui组件库( 计数器组件 )
Aug 08 Javascript
对layui中table组件工具栏的使用详解
Sep 19 Javascript
JavaScript中window和document用法详解
Jul 28 Javascript
vue-router 按需加载 component: () =&gt; import() 报错的解决
Sep 22 Javascript
js实现缓动动画
Nov 25 #Javascript
JavaScript实现缓动动画
Nov 25 #Javascript
Vue3配置axios跨域实现过程解析
Nov 25 #Vue.js
Vue使用Element实现增删改查+打包的步骤
Nov 25 #Vue.js
JavaScript实现网页动态生成表格
Nov 25 #Javascript
vue + el-form 实现的多层循环表单验证
Nov 25 #Vue.js
JavaScript实现HTML导航栏下拉菜单
Nov 25 #Javascript
You might like
一棵php的类树(支持无限分类)
2006/10/09 PHP
php 字符串替换的方法
2012/01/10 PHP
解析php中的escape函数
2013/06/29 PHP
PHP中如何实现常用邮箱的基本判断
2014/01/07 PHP
DEDECMS首页调用图片集里的多张图片
2015/06/05 PHP
Zend Framework框架中实现Ajax的方法示例
2017/06/27 PHP
php数据结构之顺序链表与链式线性表示例
2018/01/22 PHP
PHP5.5新特性之yield理解与用法实例分析
2019/01/11 PHP
基于Jquery与WebMethod投票功能实现代码
2011/01/19 Javascript
js格式化金额可选是否带千分位以及保留精度
2014/01/28 Javascript
JavaScript输出当前时间Unix时间戳的方法
2015/04/06 Javascript
javascript使用shift+click实现选择和反选checkbox的方法
2015/05/04 Javascript
JS实现网页上随机产生超链接地址的方法
2015/11/09 Javascript
JS定时检测任务任务完成后执行下一步的解决办法
2016/12/22 Javascript
详解javascript中对数据格式化的思考
2017/01/23 Javascript
jQuery表格(Table)基本操作实例分析
2017/03/10 Javascript
详解如何将angular-ui的图片轮播组件封装成一个指令
2017/05/09 Javascript
详解使用nvm管理多版本node的方法
2017/08/30 Javascript
JavaScript时间日期操作实例小结【5个示例】
2018/12/22 Javascript
JavaScript实现页面中录音功能的方法
2019/06/04 Javascript
JavaScript实现留言板案例
2020/03/17 Javascript
Python从MP3文件获取id3的方法
2015/06/15 Python
Python字符串的全排列算法实例详解
2019/01/07 Python
详解python做UI界面的方法
2019/02/27 Python
Django中使用session保持用户登陆连接的例子
2019/08/06 Python
Python中os模块功能与用法详解
2020/02/26 Python
JetBrains PyCharm(Community版本)的下载、安装和初步使用图文教程详解
2020/03/19 Python
CSS3教程:background-clip和background-origin
2008/10/17 HTML / CSS
用html5的canvas画布绘制贝塞尔曲线完整代码
2013/08/14 HTML / CSS
韩国演唱会订票网站:StubHub韩国
2019/01/17 全球购物
上班玩游戏检讨书
2014/02/07 职场文书
周年庆典主持词
2014/04/02 职场文书
项目合作意向书模板
2014/07/29 职场文书
理财计划书
2014/08/14 职场文书
ORACLE数据库应用开发的三十个注意事项
2021/06/07 Oracle
Python中非常使用的6种基本变量的操作与技巧
2022/03/22 Python