热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

不同CSS技术及其CSS性能

翻译-不同CSS技术及其CSS性能原作者:DaveGregory原文地址:http:screwlewse.com20…d-their-performance翻译:张

翻译-不同CSS技术及其CSS性能

原作者:Dave Gregory
原文地址:http://screwlewse.com/20…d-their-performance/
翻译:张鑫旭

//zxx:以下非特别标注的内容均来自原文,不代表个人观点

一、为什么我要测试CSS的性能

这是背景:

我是OOCSS(译者注:面向对象CSS)的忠实粉丝。但是最近工作,我一直使用Compass,SASS(译者注:SASS使CSS函数化,有诸如变量,嵌套,混合,继承等特性,需Ruby支持).我有时候感觉到OOCSS和SASS似乎有点古怪。我的一个朋友把我介绍给了Chris Eppstein(Compass的创建者),我们就SASS中的@extend方法进行了探讨。所以我决定创建一个CSS测试页面,用一种很原生态的方式来显示是否SASS的@extend方法和CSS的OOCSS方法之间有着显著的性能差异。

译者补充,下图为SASS@extend继承实现的示例截图:
SASS @extend使用截图

关于OOCSS,Nicole Sullivan有份不错的ppt教案,具体见下面:

Object Oriented CSS查看更多Nicole Sullivan的presentations.

本想翻译下的,结果此幻灯片被作者设置为不能下载,要是自己翻译并重新制作份幻灯片,是腾不出那么多时间的,所以作罢。其有两个主要原则:

* 分离结构和皮肤
* 分离容器和内容

此原则多少与自己“CSS样式分离之再分离”一文中提到的一些思想类似。

 

二、测试如何工作的

此测试制造了差不多2000个box,所有的box都有一个独一无二的背景(样式)。有几种格式用来测试(见下面的链接),你可以逐个更改以测试器速度的差异。只要根据您的意愿点击相应的链接。

此测试用了一小段脚本,此段脚本来自Steve Souder的博文:Performance Impact of CSS Selectors(CSS选择器的性能影响)

Steve的文章可以说是进入了CSS选择器性能更细致的一个境界,非常值得阅读。

三、CSS格式

1. OOCSS (似乎挺快的),双class,如:class="box box-#",基本的CSS样式在class box中,然后直添加背景样式在唯一的class中。

2. Sass @extend (速度不确定),一个class,如class="box-3",然后在基本规则上创建一个多选择器规则,如.box-1, .box-2 {generics}

3. 嚣张的CSS 添加所有的基本CSS到一个唯一的class上,没有“瘦身”。

4. 使用ID选择器 虽然我不建议使用ID,但是用来测试还是值得一试的。

5. 没有CSS 很好的底线测试

代码示例?

OOCSS样式:一个主class,包含所有的共同规则,然后一个独特的规则使用其他class

  1. .box {padding:25px;border:1px solid #000;border-radius:5px;}
  2. .box-1 {background-color:#FFEE00;}
  3. .box-2 {background-color:#00FFee;}

@extend样式:将所有的独特class归为一个,逗号分隔的使用公用属性的class列表。

  1. .box-1,.box-2 {padding:25px;border:1px solid #000;border-radius:5px;}
  2. .box-1 {background-color:#FFEE00;}
  3. .box-2 {background-color:#00FFEE;}

长(肿胀)样式:所有的公共样式都分离到独一无二的class中。

  1. .box-1 {
  2.   padding:25px;
  3.   border:1px solid #000;
  4.   border-radius:5px;
  5.   background-color:FFEE00;}
  6. .box-2 {
  7.   padding:25px;
  8.   border:1px solid #000;
  9.   border-radius:5px;
  10.   background-color:00FFEE;}

无CSS:有点儿自我解释

四、测试结果

测试结果貌似挺有趣的,让我们看看一些图表好吗?

opera浏览器下测试结果

firefox浏览器下测试结果

Chrome6浏览器下测试结果

Safari浏览器下测试结果

所以让我们先讨论下CSS性能,这里有些我发现的东东:

  • 类(class)选择器和ID选择器基本上是相同的速度
  • SASS/Compass的@extend格式仅稍稍落后于OOCSS格式
  • 臃肿的格式在大数量级速度比其他格式明显要慢
  • 即使是极端的情况,最好与最坏的时间差异也在100-200毫秒之间

还有浏览器性能要注意的(加分):

  • 大多数浏览器的表现大致相同,只是略快一些
  • 火狐是测试的浏览器中最慢的
  • Opera渲染快速的CSS最快,渲染慢速的CSS最慢

还有就是我自己测试后的个人结论:

  • OOCSS和@extend格式相当快
  • 肿胀的CSS有害性能

哦,,差点忘了,这里是测试页面。

更新:
在测试中我发现有一些出入,可能影响测试,所以我删除任何外部引用的文件,和其他可能影响CSS性能的东东(像是text-shadow)。


推荐阅读
  • 如何压缩网站页面以减少页面加载时间
    本文介绍了影响网站打开时间的两个因素,即网页加载速度和网站页面大小。重点讲解了如何通过压缩网站页面来减少页面加载时间。具体包括图片压缩、Javascript压缩、CSS压缩和HTML压缩等方法,并推荐了相应的压缩工具。此外,还提到了一款Google Chrome插件——网页加载速度分析工具Speed Tracer。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • Ubuntu安装常用软件详细步骤
    目录1.GoogleChrome浏览器2.搜狗拼音输入法3.Pycharm4.Clion5.其他软件1.GoogleChrome浏览器通过直接下载安装GoogleChro ... [详细]
  • 本文介绍了响应式页面的概念和实现方式,包括针对不同终端制作特定页面和制作一个页面适应不同终端的显示。分析了两种实现方式的优缺点,提出了选择方案的建议。同时,对于响应式页面的需求和背景进行了讨论,解释了为什么需要响应式页面。 ... [详细]
  • 本文介绍了网页播放视频的三种实现方式,分别是使用html5的video标签、使用flash来播放以及使用object标签。其中,推荐使用html5的video标签来简单播放视频,但有些老的浏览器不支持html5。另外,还可以使用flash来播放视频,需要使用object标签。 ... [详细]
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了markdown[软件代理设置]相关的知识,希望对你有一定的参考价值。 ... [详细]
  • css div中文字位置_超赞的 CSS 阴影技巧与细节
    本文的题目是CSS阴影技巧与细节。CSS阴影,却不一定是box-shadow与filter:drop-shadow,为啥?因为使用其他属性 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • PHP引用的概念和用法详解
    本文详细介绍了PHP中引用的概念和用法。引用是指不同的变量名访问同一个变量内容,类似于Unix文件系统中的hardlink。文章从引用的定义、作用、语法和注意事项等方面进行了解释和示例。同时还介绍了对未定义变量使用引用的情况,以及在函数和new运算符中使用引用的注意事项。 ... [详细]
  • TPL实现Task.WhileAll扩展方法
    文章翻译整理自NikolaMalovic两篇博文:Task.WhileAllAwaitabletaskprogressreporting当Task.WhenAll遇见 ... [详细]
  • SQL Server 2008 到底需要使用哪些端口?
    SQLServer2008到底需要使用哪些端口?-下面就来介绍下SQLServer2008中使用的端口有哪些:  首先,最常用最常见的就是1433端口。这个是数据库引擎的端口,如果 ... [详细]
author-avatar
夕阳隐日
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有