详解CSS3开启硬件加速的使用和坑


Posted in HTML / CSS onAugust 21, 2017

前言

最近在看在github上看iscroll的文档。虽然是英文的,但是为了装逼,没办法硬着头皮看完了,觉得作者写得不错(我有那么好耐心写那么长的文档就好了[捂脸]),然后为了更好地装逼,有看了一遍,其中是发现了不少好东西的,比如说 CCS3硬件加速 就是在上面被我扩展出来的。为了大家可以一起愉快地玩耍,我就先附上iscroll的Github Link:https://github.com/issaxite/iscroll

开启CSS3加速

平时我们写的css3动画(没有触发硬件加速的)都是使用浏览器缓慢的软件渲染引擎来执行,字面上意思就是没有开启硬件加速。比如有时候写的移动端网页的动画(比如最简单的模态框)在安卓手机上会出现卡帧的现象,有很大可能就是使用浏览器软件渲染引擎来执行,性能跟不上导致的。上面说到 硬件加速 就可以解决这个问题,性能跟不上嘛,那就Spider Man上(能力越大,责任越大)——来硬件加速,性能提上去呀(我知道这又是一个烂gag),其实所谓硬件加速就是告诉浏览器,让它使用GPU进行渲染,切换到GPU模式,发挥GPU的一系列功能。

举个例子:

CSS的  animations,  transforms 以及 transitions 不会自动开启GPU加速,而是由浏览器的缓慢的软件渲染引擎来执行。为了性能,这个时候或许你就需要开启硬件加速功能。那我们怎样才可以切换到GPU模式呢,很多浏览器提供了某些触发的CSS规则。

Chrome, FireFox, Safari, IE9+和最新版本的Opera都支持硬件加速,当它们检测到页面中某个DOM元素应用了某些CSS规则时就会开启,最显著的特征的元素的3D变换。

在其他的文章上看到的几个可以切换到GPU模式的几个3d属性:

.isaax{
   -webkit-transform: translate3d(250px,250px,250px)
   rotate3d(250px,250px,250px,-120deg)
   scale3d(0.5, 0.5, 0.5);
}

在iscroll的文档上看到的是下面这个:

详解CSS3开启硬件加速的使用和坑

.isaax {
   -webkit-transform: translateZ(0);
   -moz-transform: translateZ(0);
   -ms-transform: translateZ(0);
   -o-transform: translateZ(0);
   transform: translateZ(0);
}

据说使用以上样式触发硬件加速后会出现 “页面可能会出现闪烁的效果“ 的问题,我是还没有发现,在网上是找到两个可以解决的方法:

方法一

.isaax {
   -webkit-backface-visibility: hidden;
   -moz-backface-visibility: hidden;
   -ms-backface-visibility: hidden;
   backface-visibility: hidden;
 
   -webkit-perspective: 1000;
   -moz-perspective: 1000;
   -ms-perspective: 1000;
   perspective: 1000;
}
  • backface-visibility (ie10+)是用来隐藏被旋转元素的背面,translateZ 导致的?;
  • 而当为元素定义 perspective 属性时,其子元素会获得透视效果。

换言之,并不是去掉闪烁,而是设成透明[技术太渣根本不敢说话]

方法二

如果是webkit内核,还有一种方式可以解决:

.isaax {
   -webkit-transform: translate3d(0, 0, 0);
   -moz-transform: translate3d(0, 0, 0);
   -ms-transform: translate3d(0, 0, 0);
   transform: translate3d(0, 0, 0);
}

硬件加速的坑

看了大神的文章才知道,握草,这东西也不是万金油啊,用得不好,狠起来你那女票还狠,看了打开大神的例子又再次感受到深深的恶意。头部的那个轮播动画元素的存在居然会导致下面所有相对和绝对定位的元素都被放到复合层中。。。

然后说一下怎么打开查看【复合层】元素选项的方式,好像上面文章提到的方法有点过时:

打开控制台

详解CSS3开启硬件加速的使用和坑

勾选Layer Borders选项,你会发现世界突然清晰了许多

详解CSS3开启硬件加速的使用和坑

最后,附上跳过坑的方法

使用3D硬件加速提升动画性能时,最好给元素增加一个z-index属性,人为干扰复合层的排序,可以有效减少chrome创建不必要的复合层,提升渲染性能,移动端优化效果尤为明显。

.isaax{
  position: relative;
  z-index: 1;  // 可以设大点,尽量设得比后面元素的z-index值高
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
使用简单的CSS3属性实现炫酷读者墙效果
Jan 08 HTML / CSS
CSS3.0实现霓虹灯按钮动画特效的示例代码
Jan 12 HTML / CSS
HTML5打开本地app应用的方法
Mar 31 HTML / CSS
HTML5 本地存储和内容按需加载的思路和方法
Apr 07 HTML / CSS
html5使用canvas画三角形
Dec 15 HTML / CSS
HTML5 History API 实现无刷新跳转
Jan 11 HTML / CSS
Html5实现移动端、PC端 刮刮卡效果
Jun 30 HTML / CSS
HTML5超炫酷粒子效果的进度条的实现示例
Aug 23 HTML / CSS
HTML5实现直播间评论滚动效果的代码
May 27 HTML / CSS
AmazeUI底部导航栏与分享按钮的示例代码
Aug 18 HTML / CSS
ivx平台开发之不用代码实现一个九宫格抽奖功能
Jan 27 HTML / CSS
HTML页面滚动时部分内容位置固定不滚动的实现
Apr 14 HTML / CSS
前端面试必备之CSS3的新特性
Sep 05 #HTML / CSS
纯CSS实现预加载动画效果
Sep 06 #HTML / CSS
使用CSS3制作倾斜导航条和毛玻璃效果
Sep 12 #HTML / CSS
分享8款纯CSS3实现的搜索框功能
Sep 14 #HTML / CSS
详解CSS3 用border写 空心三角箭头 (两种写法)
Sep 29 #HTML / CSS
详解使用CSS3的@media来编写响应式的页面
Nov 01 #HTML / CSS
CSS3轻松实现圆角效果
Nov 09 #HTML / CSS
You might like
php横向重复区域显示二法
2008/09/25 PHP
PHP自定义函数判断是否为Get、Post及Ajax提交的方法
2017/07/27 PHP
深入解析Laravel5.5中的包自动发现Package Auto Discovery
2017/09/13 PHP
一个简单的js鼠标划过切换效果
2010/06/30 Javascript
javascript客户端遍历控件与获取父容器对象示例代码
2014/01/06 Javascript
jquery常用特效方法使用示例
2014/04/25 Javascript
jquery操作checked属性以及disabled属性的多种方法
2014/06/20 Javascript
js获取元素相对窗口位置的实现代码
2014/09/28 Javascript
使用node+vue.js实现SPA应用
2016/01/28 Javascript
javascript html5实现表单验证
2016/03/01 Javascript
如何选择jQuery版本 1.x? 2.x? 3.x?
2017/04/01 jQuery
jQuery实现base64前台加密解密功能详解
2017/08/29 jQuery
JQ图片文件上传之前预览功能的简单实例(分享)
2017/11/12 Javascript
javascript用rem来做响应式开发
2018/01/13 Javascript
vue.js配合$.post从后台获取数据简单demo分享
2018/08/11 Javascript
基于elementUI实现图片预览组件的示例代码
2019/03/31 Javascript
express中static中间件的具体使用方法
2019/10/17 Javascript
在vue中对数组值变化的监听与重新响应渲染操作
2020/07/17 Javascript
[01:41]DOTA2 2015国际邀请赛中国区预选赛第三日战报
2015/05/28 DOTA
[55:54]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
Python DataFrame 设置输出不显示index(索引)值的方法
2018/06/07 Python
Python函数的参数常见分类与用法实例详解
2019/03/30 Python
python并发编程多进程 互斥锁原理解析
2019/08/20 Python
python numpy中cumsum的用法详解
2019/10/17 Python
Python GUI库PyQt5图形和特效样式QSS介绍
2020/02/25 Python
Python批量获取并保存手机号归属地和运营商的示例
2020/10/09 Python
CSS3制作酷炫的条纹背景
2017/11/09 HTML / CSS
Hibernate持久层技术
2013/12/16 面试题
网上开店必备创业计划书
2014/01/26 职场文书
党员入党表决心的话
2014/03/11 职场文书
绿色环保演讲稿
2014/05/10 职场文书
营业员岗位职责
2015/02/11 职场文书
学生检讨书怎么写
2015/05/07 职场文书
丧事答谢词大全
2015/09/30 职场文书
2016春季校长开学典礼致辞
2015/11/26 职场文书
InterProcessMutex实现zookeeper分布式锁原理
2022/03/21 Java/Android