基础概念

  CSS样式可分为两种,一种值接近无限的集合(color,width),一种值只有几种(display),可以进行计算的样式,产生了动画效果。\

  1. 动画的第一步是获得元素的精确样式值。

  2. 若要做平移,传入结束位置、距离、时长、fps。

tips:fps设置多少合适?

  除了人的眼睛,还要考虑到显示器的显示速度与浏览器的渲染速度。据国外统计,根据人所能感知到的变化间隔,25毫秒为最佳数值。

缓动公式

  

  缓动公式来源于数学上的三角函数、二次项方程、高阶方程式,有了公式就可以控制移动速度。

  一般情况下,只会用默认的linear或easeIn。现在所有的缓动公式,除了linear外都以ease开头命名,添加三种后缀,In代表加速、Out代表减速、InOut代表先加速后减速,于是有easeIn、easeOut、easeInOut之分。这种命名表示没有介入高阶函数与三角函数,linear表示匀速。

CSS3 transition

  transition是CSS入侵行为层的主要行为。

  包含4个属性,样式名、持续时间、缓动公式、延迟多久才触发。

transition-property

  指定属性执行transition效果,主要有以下几个值:none(无)、all(所有属性 默认值)、indent(元素属性名)。

  如果指定属性,可以选择的类型如下:

  1、与颜色相关的属性,如background-color,border-color,color,outline-color。

  2、与盒子模型、字体大小、间距、行高有关样式。如width、top、margin、line-height等。

  3、透明度 opacity。

  4、变形相关 即transform。

  5、阴影 text-shadow box-shadow。

  6、线性渐变与径向渐变。

transition-duration

  动画持续时间,单位可以是s,也可以是ms。

transition-timing-function

  缓动公式。有6个可能的值

  1、ease:逐渐变慢(默认值)

  2、linear:匀速

  3、ease-in:加速

  4、ease-out:减速

  5、ease-in-out:先加速后减速

  6、cubic-bezier:允许自定义一个时间曲线。(x1,y1,x2,y2),四个值对应贝塞尔曲线的4个点,值需定义在[0,1]之间。

transition-delay

  延迟执行时间,可选单位s或ms。

  该属性缺点是不可控,无法暂停,一般框架不会用这个来实现动画引擎。

CSS3 animation

  

  

  吸收了Flash的关键帧理念,并克服了transition的一些缺陷。

  animation是一个复合样式,可以细分为8个更细的样式,情况与background-*关系相仿。

  

1、animation-name

  制约关键帧样式的名字,可以同时对应多个关键帧样式规则名,以‘,’号分开。

2、animation-duraiton

  动画持续时间,单位为s或ms。

3、animation-timing-function

  缓动公式。

4、animation-delay

  动画延迟多久才开始,不计入duration。

5、animation-iteration-count

  动画播放次数,值可以为正整数或infinite,默认只执行一次。

6、animation-direction

  动画执行的方向,有四个值:normal、alternate、reverse、alternate-reverse。

  normal:指每次都从第一帧开始。

  alternate:count大于1有效,动画从0%-100%,100%-0%循环。

  reverse:有兼容问题,与normal相反,从最后一帧开始。

  alternate-reverse:有兼容问题,与alternate相反。

7、animation-fill-mode

  指动画跑完一圈,是保持动画前的状态还是此时的状态。

8、animation-play-state

  用于暂停或继续此动画。

  除了最后两个,前六个可以写在一块。

JS框架设计读书笔记之-动画的更多相关文章

  1. JS框架设计读书笔记之-节点模块

    节点的创建 浏览器提供了多种手段创建API,从流行程度依次是document.createElement.innerHTML.insertAdjacentHTML.createContextualFr ...

  2. JS框架设计读书笔记之-核心模块

    随笔记录一下读书心得 1. 框架模块-核心模块 该模块是框架最先执行的部分,jQuery与vue中都有初始化的代码. 模块的功能主要是:对象扩展.数组化.类型判定.事件绑定和解绑.无冲突处理.模块加载 ...

  3. JS框架设计读书笔记之-选择器引擎01

    选择符 选择符是指CSS样式规则最左边的部分,例如 p{},#id{},.class{},p.class{} 等等 总共可以分为四大类: 并联选择器 => 逗号 => $('div,spa ...

  4. JS框架设计读书笔记之-小知识

    这一篇写一点小知识 JS中0.1+0.2为什么不等于0.3? 关于这个问题之前也很疑虑,老师也只是笼统的讲这是JS的语言问题,但是内部具体的情况却没有讲,看了书才发现原理如此简单. 简单来讲,计算机识 ...

  5. JS框架设计读书笔记之-异步

    setTimeout/setInterval 1. 如果回调执行时间大于间隔时间,真正的间隔时间会大一些. 2. 存在一个最小的时间间隔,即使seTimeout(fn,0),在IE6-IE8中大概为1 ...

  6. JS框架设计读书笔记之-选择器引擎02

    选择器引擎涉及相关概念 概念 以Sizzle的主函数声明为例,来说明引擎的相关概念. function Sizzle(selector, context, results, seed) { //... ...

  7. JS框架设计读书笔记之-函数

    这次写一些函数 1.模拟Object.keys方法 Object.keys = Object.keys || function(obj){ var a = []; // a[0],a[1]...分别赋 ...

  8. javascript框架设计(读书笔记)

    我觉得多看几本进阶的书 与其十本书读一遍,不如一本书读十遍 读书的启示: 读好书(看推荐) 精读(重复看) 能读厚书(javascript权威指南) Object.keys Object.keys=O ...

  9. js框架设计1.1命名空间笔记

    借到了司徒正美的写的js框架设计一书,司徒大神所著有些看不太懂,果然尚需循序渐进,稳扎js基础之中. 第一张开篇司徒阐述了种子模块的概念 种子模块亦为核心模块,框架最先执行模块,司徒见解应包含:对象扩 ...

随机推荐

  1. Oracle-更新字段-一张表的字段更新另一张的表的字段

    设备表ops_device_info中的终端号terminal_id值是以 'D'开头的字符串,而终端表ops__terminal_info中的终端号terminal_id是8位字符串, 它们之间是通 ...

  2. Thinkphp5.0 在自己定义一个公共方法的控制器并且继承了Controller类的时候报错

    在建立网站的时候,你通常想着把一些共有的方法提取出来,放入一个控制器内,如果你是将业务逻辑写入了构造函数里面,那么就得注意了. 在thinkphp5.0当中,有一个初始化的方法,类似于构造函数,那就是 ...

  3. 学习率 Learning Rate

    本文从梯度学习算法的角度中看学习率对于学习算法性能的影响,以及介绍如何调整学习率的一般经验和技巧. 在机器学习中,监督式学习(Supervised Learning)通过定义一个模型,并根据训练集上的 ...

  4. 在Storyboard中为UITableView添加Header和Footer

    我在这里所说的Header和Footer并不是sectionHeader和sectionFooter,而是指UITableView的tableHeaderView和tableFooterView,这两 ...

  5. 实例讲解webpack的基本使用第三篇

    这一篇来讲解一下webpack的htmlWebpackHtml插件的使用. 先来思考一个实际问题:我们现在在index.html引用的js文件是写死的.但是我们每次打包后的文件都是动态的,那么我们怎么 ...

  6. 翻译:MLAPP(2.2节 概率论简要回顾)

    笔者:尝试翻译MLAPP(Machine Learning: a Probabilistic Perspective)一书,供机器学习的学者参考,如有错误理解之处请指出,不胜感激!(如需转载,请联系本 ...

  7. POJ1032 Parliament(数论)

    New convocation of The Fool Land's Parliament consists of N delegates. According to the present regu ...

  8. localStorage和sessionStorage总结以及区别

    (1)兼容的手机和浏览器: (2)使用 .setItem( key, value)存键值数据 sessionStorage.setItem("key","value&qu ...

  9. git fsck -- 一致性检查

    格式:           git fsck  [选项] <path> 选项 git commit -a 提交所有改动的文件(a -- all) git commit -m 提交说明(m ...

  10. 基于搜狗搜索的微信公众号爬虫实现(C#版本)

    Author: Hoyho Luo Email: luohaihao@gmail.com Source Url:http://here2say.me/11/ 转载请保留此出处 本文介绍基于搜狗的微信公 ...