前端写动画,无非两种方案,一种是通过css,另一种是js
css的方案:
1.transform的单独使用 (IE9+)
rotate(90deg) 2d旋转,也可以理解为沿着3D的Z轴旋转
rotateX(90deg) 沿着3D的X轴旋转,同理还有rotateY rotateZ
translate(100px, 50px) 沿着X方向 Y方向移动100px, 50px
scale(2) 缩放 定义 2D 缩放转换。
skew 斜切 沿着 X 和 Y 轴的 2D 倾斜转换 (平行四边形、梯形的实现)
更详细的transform属性请点击 http://www.w3school.com.cn/cssref/pr_transform.asp
2.transition的单独使用 (IE10及以上)
元素指定的属性变化时,该属性经过一段时间逐渐的过渡到最终需要的值
特点:需要事件(hover,focus,js)触发,不能重复,不能定义中间状态
  • transition-property css属性名称(所有属性 'all')
  • transition-duration 过渡时间
  • transition-timing-function 速度曲线
  • transition-delay 延迟时间
四个属性可以简写,如 transition: width 1s ease 0.2s
 
3.animation单独使用 (IE10及以上)
  • animation-name key-frame名称
  • animation-duration 过渡时间
  • animation-timing-function 速度曲线
  • animation-delay 延迟
  • animation-iteration-count 播放次数 无限'infinite'
  • animation-direction 是否应该轮流反向播放
六个属性可以简写
 
transition和animation的差异:
1.transition动画的执行过程就是声明关键帧的过程,而animation动画的事先声明关键帧(@keyframes),然后再调用关键帧
2.transition动画的执行需要有事件(hover、点击事件)来驱动,而animation动画的执行不一定需要驱动
3.transition 不能无限循环,不能指定播放次数,只能定义头尾帧。
 
animation与transform的混合应用demo:
.App-logo {
position: absolute;
top: 10px;
left: 10px;
animation: App-logo-spin infinite 2s linear;
height: 80px;
}
 
@keyframes App-logo-spin {
50% {
transform: translate(100px, 100px) // 使用translate代替absolute
// top: 100px;
// left: 100px;
}
}
 
js的方案
1.setTimeOut/setInterval (不推荐)
2.requestAnimationFrame(兼容性ie10以上)
 
关于requestAnimationFrame
window.requestAnimationFrame()接收一个函数作为回调,返回一个id
window.cancelAnimationFrame()传入id取消动画
为什么推荐使用requestAnimationFrame而不是setTimeOut/setInterval?
1.requestAnimationFrame 会把每一帧的所有DOM操作集中起来,在一次重绘或回流中完成。且重绘或回流的时间间隔紧跟随浏览器的刷新频率
3.在隐藏或不可见的元素中,requestAnimationFrame将不会重绘和回流,节省的CPU、GPU、内存使用
4.requestAnimationFrame是浏览器专为动画提供的API,浏览器会自动优化方法的调用,若页面不是激活状态,动画自动暂停,节省CPU
 
最后的总结
1. 尽可能的使用CSS 关键帧动画或者CSS transition。浏览器可以优化大量绘制和组合的时间。
 
2. 如果一定使用基于JS的动画,尽量使用requestAnimationFrame。尽量不要使用setTimeout, setInterval。
 
3. 尽量不要在每一帧上改变inline元素,浏览器可以在多方面优化css中声明式动画。
 
4. 使用2D transforms来代替position:absolution将会显著的提高FPS(每秒传输帧数),因为2D transform有更少的绘制时间和更流畅的动画。 通过改变元素top/left进行动画,在每一帧内,cpu都需要计算该元素的其他样式,特别是相对需要复杂计算的盒阴影,渐变,圆角等样式,最后都需要将这些样式应用到该元素内。从这个角度看,如果对于较为老旧的移动设备进行相对复杂的动画,那么效果肯定不理想。
而通过调用translate,会启动硬件加速,即在GPU层对该元素进行渲染。这样,CPU就会相对解放出来进行其他的计算,GPU对样式的计算相对较快,且保证较大的帧率。我们可以通过2d和3d的transform来启用GPU计算。
 
5. chrome(版本69.0)可以通过Timeline Frams模式来观测什么让你变慢
6.chrome(版本69.0)可以通过animations来对动画进行微调
6.文章排版还有待加强

web动画小结的更多相关文章

  1. 高性能Web动画和渲染原理系列(1)——CSS动画和JS动画

    [摘要] 介绍CSS动画和JS动画的基本特点,以及轻量级动画库velocity.js的基本用法. 示例代码托管在:http://www.github.com/dashnowords/blogs 博客园 ...

  2. 【Web动画】SVG 实现复杂线条动画

    在上一篇文章中,我们初步实现了一些利用基本图形就能完成的线条动画: [Web动画]SVG 线条动画入门 当然,事物都是朝着熵增焓减的方向发展的,复杂线条也肯定比有序线条要多. 很多时候,我们无法人工去 ...

  3. 【Web动画】SVG 线条动画入门

    通常我们说的 Web 动画,包含了三大类. CSS3 动画 javascript 动画(canvas) html 动画(SVG) 个人认为 3 种动画各有优劣,实际应用中根据掌握情况作出取舍,本文讨论 ...

  4. 【Web动画】CSS3 3D 行星运转 && 浏览器渲染原理

    承接上一篇:[CSS3进阶]酷炫的3D旋转透视 . 最近入坑 Web 动画,所以把自己的学习过程记录一下分享给大家. CSS3 3D 行星运转 demo 页面请戳:Demo.(建议使用Chrome打开 ...

  5. HTML5探秘:用requestAnimationFrame优化Web动画

    本文转载自: HTML5探秘:用requestAnimationFrame优化Web动画

  6. 流畅web动画的十个法则

    from me: web动画能够带来一个非常酷炫的效果,能够让页面有一个更好的用户体验.对于良好的动画性能没有高招,除了将大量的时间放在测试和优化,当然最重要的还是要易于维护. 流畅web动画的十大法 ...

  7. Web动画API教程2:AnimationPlayer和Timeline

    本文转载: Web动画API教程2:AnimationPlayer和Timeline

  8. Web动画API教程1:创建基本动画

    本人转载自: Web动画API教程1:创建基本动画

  9. Web 动画帧率(FPS)计算

    我们知道,动画其实是由一帧一帧的图像构成的.有 Web 动画那么就会存在该动画在播放运行时的帧率.而帧率在不同设备不同情况下又是不一样的. 有的时候,一些复杂或者重要动画,我们需要实时监控它们的帧率, ...

随机推荐

  1. getdlgitemtext

    获取控件内信息 set 设置控件内信息 oninitdialog初始化控件时的操作

  2. MySQL操作数据库和表的基本语句(DDL

    1.创建数据库: CREATE DATABASE 数据库名; eg.CREATE DATABASE test_ddl;122.创建表 CREATE TABLE 表名(列名 数据类型 约束,...); ...

  3. c# winform中使用WebKit实现网页与winform的交互

    1.工作 一年多了,一直没对自己在工作遇到的问题进行总结,每次遇到问题都要在网上找资料,导致完成项目之后,时间久了就会生疏.所以下定 决定总结自己在工作中遇到的各种问题. 进入正题:第一次写还请大神多 ...

  4. exist not exist 分析

    结果集1 结果集2: 最后连接条件 执行过程: 一行一行遍历结果集1的数据,然后结果集1中的连接条件执行子查询,如果有值返回那么在看是exist  还是not exist 在决定最后的结果集是否要要不 ...

  5. MongoDB - 认识MongoDB及数据类型

    目录 MongoDB - 认识MongoDB及数据类型 启动 MogoDB的数据 MogoDB的数据类型 1.Object ID : Documents自生成的_id 2.string : 字符串,必 ...

  6. seleniumd对象的操作方法,属性,keys

    这是通过find方法找到的页面元素,此对象提供了多种方法,让我们可以与页面元素进行交互,例如点击.清空. 目录: 1. 方法 2. 属性 3. keys 方法 clear()清空 如果当前元素中有文本 ...

  7. 【codeforces 785E】Anton and Permutation

    [题目链接]:http://codeforces.com/problemset/problem/785/E [题意] 给你一个初始序列1..n顺序 然后每次让你交换任意两个位置上面的数字; 让你实时输 ...

  8. 倍增/线段树维护树的直径 hdu5993/2016icpc青岛L

    题意: 给一棵树,每次询问删掉两条边,问剩下的三棵树的最大直径 点10W,询问10W,询问相互独立 Solution: 考虑线段树/倍增维护树的直径 考虑一个点集的区间 [l, r] 而我们知道了有 ...

  9. windows下db2的一些使用心得(不含安装)

    1.安装完成后开始菜单栏里会有一个 DB2 Command Window - Administrator 打开这个命令窗口 2.db2 db2,启动 3.list databse directory ...

  10. K - Count the string kmp_Next数组应用

    It is well known that AekdyCoin is good at string problems as well as number theory problems. When g ...