位置: 编程技术 - 正文

jQuery 1.9.1源码分析系列(十五)动画处理之缓动动画核心Tween(jquery源码下载)

编辑:rootadmin

推荐整理分享jQuery 1.9.1源码分析系列(十五)动画处理之缓动动画核心Tween(jquery源码下载),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery animate源码,jquery源码是什么水平,jquery源码分析,jquery fadein 源码,jquery fadein 源码,jquery fadein 源码,jquery.min.js源代码,jquery源码是什么水平,内容如对您有帮助,希望把文章链接给更多的朋友!

在jQuery内部函数Animation中调用到了createTweens()来创建缓动动画组,创建完成后的结果为:

  可以看到上面的缓动动画组有四个原子动画组成。每一个原子动画的信息都包含在里面了。

  仔细查看createTweens函数,实际上就是遍历调用了tweeners ["*"]的数组中的函数(实际上就只有一个元素)。

  再次查看这个tweeners ["*"][0]函数,主要代码如下

  可以看出除了hide/show两种动画外的其他动画都经过tweeners ["*"][0]这个函数封装了动画组。其中有几个关键的数组start/end/unit。特别是对非像素单位的动画start值获取费了一番功夫。

  还有一个比较关键的地方是都用了this.createTween获取单个css特征的基础的动画特征。而animation. createTween中直接调用jQuery.Tween来处理。接下来我们详解之。

a.jQuery.Tween

--------------------------------------------------------------------------------

  jQuery.Tween的结构和jQuery类似

  是不是有一种很熟悉的赶脚。

  里面cur函数用来获取当前的css特征值

  而run函数则会在每个动画时间点上对正在进行的动画的每个特征值进行处理。

  主要是两个步骤:

  1.计算动画当前进度pos和动画当前位置now

  2.根据当前进度情况设置css特征值

jQuery 1.9.1源码分析系列(十五)动画处理之缓动动画核心Tween(jquery源码下载)

  可见生成缓动动画这一步处理才是整个动画的核心:

  创建缓动动画组,每一个原子动画都包含了每一个原子css属性动画的各种必要参数以及动画函数

  不同的是hide/show直接在defaultPrefilter中创建了这个缓动动画组(所有的属性都默认是px单位),其他的动画在调用createTweens时创建缓动动画组。

  还记不记得在创建动画的时候有个tick函数,这个tick函数会在每隔一个步长的时间调用一次

  看到没,每一个原子动画有自己的run函数来执行自己的动画,这在创建缓动动画组的时候就建好了的。

好了,整理一下动画的整个核心流程:

  1.先根据参数调用jQuery.speed获取动画相关参数,得到一个类似如下的对象;并且生成动画执行函数doAnimation使用.queue压入队列并马上执行

  2.doAnimation中调用创建一个延时对象,使用延时对象的promise方法构造一个动画对象animation(延时对象+动画特征列表),最后给animation添加动画执行完成后的回调函数。

  3.调用jQuery内部函数proFilter修正css特征名以便能被当前浏览器识别,并将某些复合css特征分解(比如padding分解成paddingTop / Right/ Bottom/ Left).

  4.调用jQuery内部函数defaultPrefilter做动画能够正常运行前提条件修正:比如对height/width动画display和overflow需要特定的值。特别需要注意的是

对于show/hide动画,在之前就调用genFx将需要执行动画的css特征提取了出来,在defaultPrefilter函数里直接调用动画对象animation.createTween给每一个CSS动画属性添加对应的缓动动画对象(包括动画参数和动画函数如run)压入缓动动画组animation.tweens中

  5.调用jQuery内部函数createTweens将除开show/hide之外的动画每一个css动画特征使用animation.createTween创建缓动动画对象(包括动画参数和动画函数如run),压入缓动动画组animation.tweens中

  6.启动动画计时,在每个时间点上执行tick函数来给相应的css特征值设置运动值。

  其中css特征值运动的进度百分比是

  得到的percent是符合时间规律的。代入这个percent设置准确的css特征值,以刷新动画显示。

  8.动画完成后调用动画完成回调。

关于小编给大家分享的jQuery 1.9.1源码分析系列(十五)动画处理之缓动动画核心Tween 全部内容就到此结束了,有问题欢迎给我留言我会在第一时间和大家取得联系的。

ztree获取选中节点时不能进入可视区域出现BUG如何解决 zTree是一个依靠jQuery实现的多功能树插件。优异的性能、灵活的配置、多种功能的组合是zTree最大优点。zTree的特点编辑●zTreev3.0将核心代码按照功能进

jQuery 1.9.1源码分析系列(十五)之动画处理 首先需要有队列(queue)的基本知识。见上一章。相关教程:jQuery下的动画处理总结:

详解页面滚动值scrollTop在FireFox与Chrome浏览器间的兼容问题 最近做了个项目,其中有一目录功能,发现一个在现代浏览器间的一个bug,或是称之为差异,即页面滚动值(scrollTop)的获取与设定。在此之前先说一下关

标签: jquery源码下载

本文链接地址:https://www.jiuchutong.com/biancheng/376192.html 转载请保留说明!

上一篇:jQuery实现获取绑定自定义事件元素的方法(jquery绑定keyup)

下一篇:ztree获取选中节点时不能进入可视区域出现BUG如何解决(ztree getnodebytid)

  • 简易计税方法使用范围
  • 签三方协议需要什么资料
  • 城市生活垃圾费是业主出还是物业出
  • 房地产开发企业预缴增值税
  • 信用减值损失在借方
  • 小规模发票跨月冲红怎么做账
  • 公司收到的其他发票
  • 公司向股东借款计入什么科目
  • 复利现值系数和普通年金现值系数关系
  • 土地款印花税计入无形资产吗
  • 农村合作社开具的专用发票免税吗
  • 建筑业的发票
  • 企业为什么会成为非正常户
  • 请问给员工报销怎么报
  • 营业外收入不纳税?
  • 转籍车辆是什么意思
  • 行政事业性收费包括哪些项目
  • 印花税减免税额需要做账吗
  • 哪些支出可以在计算企业应纳税所得额时加计扣除
  • 按揭购入固定资产怎么算
  • 公司产品因质量问题买家追究
  • 银行承兑汇票如何承兑分录
  • 设计师用windows什么版本
  • php环境配置教程Apace
  • linux传输数据
  • php b/s
  • 授权经销书模板
  • 金融资产的条件
  • 免费设备投放项目
  • 厂房改造支出可以计入厂房价值吗
  • 深入理解php类的知识
  • mdadm命令用不了
  • 加盟代理需要什么手续
  • 对供应商的罚款通知怎么写
  • Postgresql ALTER语句常用操作小结
  • 为什么结转材料成本差异
  • 金蝶kis固定资产反结账
  • SqlServer2012中First_Value函数简单分析
  • sqlserver数据库版本号怎么查
  • 新会计准则折旧年限
  • 差旅费分摊到各部门
  • 装卸费专票
  • 应交税费属什么类科目
  • 餐具报损率一般为多少
  • 政府预算会计要素包括
  • 主营业务收入主要反映企业销售商品或劳务获得的收入
  • 固定资产清理属于什么科目借方增加还是减少
  • 工会经费与工会福利的区别
  • 公司在银行买的金条怎么入账
  • 未开票收入转为开票收入
  • 原料到产品
  • 增值税发票备注栏最新规定
  • 政府专项扶持资金
  • 往来账项询证函怎么填写
  • xp系统无法安装win7系统
  • mac怎么设置默认打开方式
  • linux批处理文件怎么写
  • windows8.1开机
  • windows xp windows
  • win7一直配置
  • 为啥没有win8 win9
  • win7如何彻底卸载软件
  • windows10总是提醒更新
  • cocos2dx入门
  • 苏州大学附属第一医院占地面积
  • express app.js
  • python问题及解决方法
  • jquery如何调用
  • Javascript字符串对象函数
  • python类属性和类方法
  • 个人所得税完税证明网上打印
  • 常州的居民医保在哪里交
  • 四川省电子税务局官网下载
  • 精准扶贫有哪些分类措施
  • 物业收电费有什么猫腻
  • 北京供暖 2020
  • 对外销售产品
  • 公司如何制定制度
  • 江苏国税发票出库时间
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设