位置: 编程技术 - 正文

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)

  • 小规模纳税人每季度超过30万交税
  • 小规模纳税人征税规定
  • 六税一费优惠政策
  • 结转成本时是否含税
  • 工程款转入冻结账户能拿回
  • 什么时候库存商品什么时候主营业务收入
  • 土地增值税申报流程
  • 支付宝怎么开个人增值税发票
  • 一般存款账户可以转账给个人吗
  • 未安装使用
  • 非盈利组织捐赠支出
  • 应交税金成负数
  • 增值税专用发票有效期是多长时间
  • 税收奖励需要纳税吗
  • 利息收入要不要交增值税?
  • 工会经费的计税依据怎么算
  • 一般纳税人施工费税率是多少
  • 营改增后转让土地使用权怎么计算增值税
  • 科研经费税收优惠
  • 享受小微企业所得税优惠条件2022
  • 计提房产税的会计分录怎样做
  • 应收和预收可以抵消吗
  • 其他债券投资出售时交易费用
  • 应付福利费科目
  • 中级会计考试考后审核需要什么资料
  • 股票退市怎样补仓
  • 使用linux命令
  • 营改增建筑业税率是多少
  • 外销收入申报表怎么填
  • 苹果手机连接电脑
  • 出口退税一般退什么税
  • 居民企业境外所得税率
  • 什么是实际成本计价
  • 项目的分包行为是否合理
  • 带你看看房间英语怎么写
  • nodejs如何与前端交互
  • php框架基础教程
  • 税控盘开票日期一般截止到下个月几号
  • 进口消费税如何计税
  • 支付银行贷款利息现金流量表填哪里
  • 货币捐赠会计分录
  • 固定资产报废后累计折旧
  • 房地产企业卖房子增值税税率
  • dedecms 收费
  • SQLite中的WAL机制详细介绍
  • mysql 5.7.20 win64 安装及配置方法
  • mongodb bi
  • 已经提完折旧的房产价值评估
  • 补缴印花税分录
  • 确认应付职工薪酬怎么算
  • 盘盈固定资产明细表
  • 息税前利润的计算公式中的利息费用
  • 建筑业营改增的主要内容
  • 失控发票补缴税款后又被稽查
  • 社保扣款上月没扣费
  • 预付卡充值可以退吗
  • 财务规定保险柜存放现金最多不超过多少
  • 酒店支付模式
  • 取得下列资产时应按公允价值计量
  • 小规模公司怎样添加员工
  • 生产型企业账务处理方法
  • win8操作
  • ddriver进程
  • win8怎么彻底删除软件
  • 延长药品使用时间的方法
  • win10 rs3
  • linux ftp创建文件夹命令
  • android环境搭建教程
  • [置顶]津鱼.我爱你
  • cocos2dx 2.2.2
  • gdi双缓冲绘制
  • unity字符串
  • nodejs require原理
  • python编写登录程序
  • Python循环遍历的题
  • 重庆市电子税务局发票查询
  • 江苏税务电子税务局电话号码
  • 已抵扣过的进项怎么做账
  • 河南省国家税务总局网站
  • 四川省人口数据资料
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设