位置: 编程技术 - 正文

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)

  • 企业所得税核定征收税率表最新
  • 耕地占用税税率变化历程
  • 企业转出多交增值税吗
  • 培训费的其他费用是什么
  • 同一家单位发票不一样
  • 办理契税需要的户口本复印件可以吗
  • 法定盈余公积可以分配给股东吗
  • 固定资产不能抵扣进项税额
  • 受赠房产转让可以免个税
  • 物流辅助服务属于什么项目
  • 吸收合并控股合并新设合并的区别
  • 小规模和一般纳税人的区别
  • 白酒的消费税怎样计算
  • 一月份的工作日是多少天
  • 公司账上的存货是怎么来的
  • 公司租入农民的房子好吗
  • 母公司开票给子公司有什么税务风险吗
  • ah股溢价是什么意思 搬砖
  • 汇算清缴退税怎么调整金额
  • 通行费发票可以抵扣吗
  • 临时工工资应该找人力资源要吗
  • 冲减预付款
  • 新企业办理地税登记流程
  • 企业转让要收多少费用
  • 哪些费用可以计入开办费
  • 代驾服务费如何计算
  • 净损益是
  • dotnetfx2.0
  • php imagettftext
  • 销售点的增值税计算公式
  • 在生产经营过程中违反什么规定
  • 增值税纳税申报表在哪里打印
  • web前端视频教程全套
  • 跨境电商企业要进入某个国家的市场 必须先做的工作是
  • 销售产品的包装费
  • phpcms使用教程
  • 企业进出口贸易
  • 小规模纳税人应交税费科目设置
  • 出口货物申报表如何填写
  • 仓库出入库账本怎么做
  • 公司保障措施
  • 年均复合增长率该怎么算?
  • sql2008收缩日志文件
  • 小规模企业主营业务成本分录
  • 业务招待费专票可以抵扣吗
  • 进项税额是意思
  • 购买原材料保险费分录
  • 一般纳税人存货成本包括增值税吗为什么
  • 带抵扣进项分录
  • 货物出去没有出口报关可以补吗
  • 车间不生产折旧计提放哪里
  • 印花税票 购买
  • 小加工厂怎么开发票
  • linux获取进程启动时间
  • linux系统配置命令
  • centos环境搭建
  • 优盘和硬盘
  • ubuntu sudo not found
  • hookproxy.dll
  • linux系统基本操作命令
  • win10关闭metro界面
  • win8系统怎么设置桌面
  • Win10更新后浏览器不能联网怎么办
  • unity 扩展编辑器
  • unity3d颜色
  • css渐变文本效果在哪
  • javascript的promise
  • shell脚本中执行命令语句
  • 简介生成
  • 在其他地方 英文
  • javascript获取数据类型
  • 基于jQuery的ajax方法封装
  • js动态添加trtd
  • 电信业务发票
  • 代扣代缴企业所得税会计分录
  • 纳税申报表保管期限为几年
  • 北京地税局上班时间查询
  • 内蒙古赤峰市房价2023年最新房价走势
  • 增值税专用发票怎么开
  • 广州代理记账公司地址
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设