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 相关文章推荐
javascript中的toFixed固定小数位数 简单实例分享
Jul 12 Javascript
jquery限定文本框只能输入数字(整数和小数)
Jan 08 Javascript
javascript函数命名的三种方式及区别介绍
Mar 22 Javascript
bootstrap PrintThis打印插件使用详解
Feb 20 Javascript
详解JS异步加载的三种方式
Mar 07 Javascript
详解AngularJS ui-sref的简单使用
Apr 24 Javascript
微信小程序获取用户openId的实现方法
May 23 Javascript
深入理解vue中的$set
Jun 01 Javascript
基于js的变量提升和函数提升(详解)
Sep 17 Javascript
浅谈webpack对样式的处理
Jan 05 Javascript
react-native聊天室|RN版聊天App仿微信实例|RN仿微信界面
Nov 12 Javascript
vue中使用vue-pdf的方法详解
Sep 05 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 self,$this,const,static,-&amp;gt;的使用
2009/10/22 PHP
php 判断IP为有效IP地址的方法
2018/01/28 PHP
ThinkPHP框架实现定时执行任务的两种方法分析
2018/09/04 PHP
jQuery对象[0]是什么含义?
2010/07/31 Javascript
js转义字符介绍
2013/11/05 Javascript
JavaScript常用小技巧小结
2014/12/29 Javascript
jQuery操作JSON的CRUD用法实例
2015/02/25 Javascript
Javascript学习之谈谈JS的全局变量跟局部变量(推荐)
2016/08/28 Javascript
浅谈Vue.use的使用
2018/08/29 Javascript
使用FormData实现上传多个文件
2018/12/04 Javascript
Python3读取UTF-8文件及统计文件行数的方法
2015/05/22 Python
通过Python实现自动填写调查问卷
2017/09/06 Python
基于Python中单例模式的几种实现方式及优化详解
2018/01/09 Python
python爬虫爬取某站上海租房图片
2018/02/04 Python
解决python中 f.write写入中文出错的问题
2018/10/31 Python
对python中if语句的真假判断实例详解
2019/02/18 Python
python从list列表中选出一个数和其对应的坐标方法
2019/07/20 Python
Python实现滑动平均(Moving Average)的例子
2019/08/24 Python
python反扒机制的5种解决方法
2021/02/06 Python
CSS3样式linear-gradient的使用实例
2017/01/16 HTML / CSS
纯CSS3绘制打火机动画火焰效果
2016/07/18 HTML / CSS
美国在线工具商店:Acme Tools
2018/06/26 全球购物
英国领先的高级美容和在线皮肤诊所:Face the Future
2020/06/17 全球购物
一百多行代码实现react拖拽hooks
2021/03/23 Javascript
自荐信不宜过于夸大
2013/11/06 职场文书
公司员工检讨书
2014/02/08 职场文书
十八届三中全会报告学习材料
2014/02/17 职场文书
《夜晚的实验》教学反思
2014/02/19 职场文书
优秀的个人求职信范文
2014/05/09 职场文书
安全生产目标管理责任书
2014/07/25 职场文书
四风问题查摆材料
2014/08/25 职场文书
质量保证书格式模板
2015/02/27 职场文书
企业战略合作意向书
2015/05/08 职场文书
高三物理教学反思
2016/02/20 职场文书
分位数回归模型quantile regeression应用详解及示例教程
2021/11/02 Python
Golang入门之计时器
2022/05/04 Golang