位置: 编程技术 - 正文

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)

  • 北京增值税发票打印边距设置
  • 上年度已交房产税减免如何做账务处理
  • 房产税城镇土地使用税税率
  • 小规模税费如何做分录
  • 期初余额有误怎么在本期做调整凭证
  • 电子发票和纸质发票只能二选一吗
  • 结转本月发生的费用
  • 当月增值税为负数
  • 公司取现需要带什么东西
  • 发票校验码看不清怎样查真伪
  • 工程结算账务处理实例
  • 没有票据怎么要账
  • 企业收到发要失控发票做进项税额转出如何做税务处理?
  • 收到销项负数发票怎么处理
  • 地方教育费附加是什么意思
  • 进项转出滞纳金规定
  • 个税提前预缴怎么入账?
  • 总公司出货分公司怎么办
  • 高杠杆资金是什么意思
  • 无票收入已报税,后来开票账务处理
  • 网店提现要多久能到账
  • 财务做账借贷分别表示
  • 境内向境外提供服务免征增值税
  • 应收单据处理包括哪些
  • 事业单位洗车费如何入账
  • 如何正确安装和使用电脑
  • 鸿蒙工具栏在哪里
  • 票据贴现公司需要资质吗
  • 如何彻底关闭电脑右下角弹窗
  • 个人所得税住房租金可以扣多少
  • 部分苹果iOS17功能延后推出
  • 公司私户利息收入怎么算
  • PHP:session_set_cookie_params()的用法_Session函数
  • 票据行为包括哪4点
  • 巴拉诺维奇市
  • thinkphp5上传图片
  • 持有至到期投资科目被取消了吗
  • 乐吾实验学校网站
  • php接收ajax请求
  • 浅水滩怎么样
  • php制作验证码
  • [Vue]Vue3学习笔记(尚硅谷)
  • 大前端入门指南
  • 深度学习参数初始化(二)Kaiming初始化 含代码
  • ahs日志
  • 未记账凭证怎么变成已记账凭证
  • 建筑行业预缴个税怎么算
  • 先开票后发货如何操作
  • 劳务成本 科目
  • 个体商户个人所得税怎么算
  • 应付职工薪酬账户的明细账户有
  • linux大版本升级
  • 怎样备份mysql数据库
  • 进仓费开票是几个点
  • 出售金融资产计入
  • 公司开出发票但未收到款如何写分录?
  • 购进农产品抵扣的税率
  • 企业股权无偿转让
  • 百旺金赋开票系统图标
  • 其他应收款待抵扣税金
  • 一家企业至少要运转几个月以上
  • linux获取进程启动时间
  • centos添加子接口
  • windows10预装
  • win7如何开启VT
  • 亲测可用抖音低价单赚派费项目
  • 忘记ubuntu root密码
  • windows7磁盘清理命令
  • js中的call方法和apply方法
  • javascript中常见的数据类型有哪些?
  • 阿里面试题和答案
  • [置顶]星陨计划
  • jquery的过滤器用于指定什么东西
  • python快捷键大全
  • 一个超简单的纸飞机
  • 移动应用界面设计形考1答案
  • 江苏国税电子税务局网登录
  • 江西国税局电话客服热线
  • 中级财务管理好难
  • 企业税务人员岗位竞聘报告怎么写
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设