不同CSS技术及其CSS性能之间的差异

所属分类: 网页制作 / CSS 阅读数: 1878
收藏 0 赞 0 分享

一、为什么我要测试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

复制代码
代码如下:

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

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

复制代码
代码如下:

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

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

复制代码
代码如下:

.box-1 {
padding:25px;
border:1px solid #000;
border-radius:5px;
background-color:FFEE00;}
.box-2 {
padding:25px;
border:1px solid #000;
border-radius:5px;
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)。

        //zxx:以上是翻译的全部

        五、简短开溜的结语

        一般来讲,一个页面的CSS渲染效率的高低与该页面的CSS量有一定的关系。使用面对对象或是我提过的分离的思想都是精简CSS,提高CSS性能的不错的手段。

        翻译能力有限,如果有什么不准确的地方欢迎指正。
        就这些。

更多精彩内容其他人还在看

CSS配合JavaScript做酷的动态页面效果

  利用CSS配合JavaScript的可以做很多更酷的动态页面效果,在本教程的最后给大家简单介绍一下CSS配合JS的应用。首先,要搞清楚事件和动作的概念。在客户端脚本中,JavaScript 通过对事件进行响应来获得与用户的交互。例如,当用户单击一个按钮或者在某段文字上移动鼠标
收藏 0 赞 0 分享

WEB标准,Web前端开发工程师必备技术列表

  想要打造并拥有一流的Web产品开发团队,在团队成员基础能力上一定要下功夫。对于Web前端产品开发来说,仅仅掌握Web1.0时代简单的"网页套接"是完全不够的。我结合自己的团队配备,特此罗列了Web前端产品工程师所涉及的技能列表如下:   通过许多实际项目,
收藏 0 赞 0 分享

用CSS制作Alpha滤镜测试板

alpha滤镜给制作网页特效提供了较大的创作空间,但由于它控制参数较多,在实际应用时,为了确定一组合适的参数值,不得不反复调整修改,在编辑窗口和预览窗口来回倒腾,甚是麻烦,本文介绍了一种简单的方法。制作一个“Alpha滤镜参数测试板”,在测试板上输入参数
收藏 0 赞 0 分享

非常流行的所谓的气泡窗口

普通的Alt无法自定义风格,而Sweet Titles通过JS脚本与CSS的集合.自定义了这种伪Alt风格. 前一段时间非常流行的,就所谓的气泡窗口(鼠标移到链接处出现的). 我们这里实现的用的是Sweet Titles的插件.显示效果完全由CSS控制.. 先下载Sweet Ti
收藏 0 赞 0 分享

CSS教程:li和ul标签用法举例

LI代码的格式化: A).运用CSS格式化列表符: ul li{ list-style-type:none; } B).如果你想将列表符换成图像,则: ul li{ list-style-type:none; list-style-image: url(/blog/images/
收藏 0 赞 0 分享

CSS教程:CSS中的定位(position)

  使用CSS来定位页面内层的位置,一直是比较难以掌握的事情,很多时候,往往被绝对定位的元素,总是以浏览器的左上角为坐标原点,此时,如果浏览器的大小改变,被定义的层就会偏离设计想要的位置,让人很挠头。   其实,要想控制好层的绝对定位,只要理解CSS中关于定位
收藏 0 赞 0 分享

CSS教程:盒模型(BOX Model)

  如果想熟练掌握DIV和CSS的布局方法,首先要对盒模型有足够的了解。每个HTML元素都可以看作一个装了东西的盒子,盒子里面的内容到盒子的边框之间的距离即填充(padding),盒子本身有边框(border),而盒子边框外和其他盒子之间,还有边界(margin),如图1所示。
收藏 0 赞 0 分享

无延迟翻滚的图形与CSS混合风格按钮

  在一个具有图形背景的按钮中添加CSS风格的文本,这种建立按钮的方法结合了具有CSS翻滚(CSS rollover)标记的开发速度和效率,从而有效地提高按钮外表图像的三维效果。   相比于常规的图形按钮,这些图形/CSS混合按钮可易于建立和载入,因为你只需要为空白按钮外面
收藏 0 赞 0 分享

css里expression实现界面对象的批量控制

用过css样式我们就知道, 可以定义一批对象的class属性来指定同一个样式来统一界面. 但如何统一同类型的对象的事件? 比如:界面有无数个 <img src="**.jpg"> 如何实现鼠标经过此图片, 图片的src变成是**_over.jpg?
收藏 0 赞 0 分享

CSS教程:水平对齐(text-align)

  水平对齐(text-align),用以设定元素内文本的水平对齐方式。   1.语法   text-align具体参数如下: 语法:text-align:left|right|center|justify 说明:设定元素内文本的水平对齐方式。 参数:left:左
收藏 0 赞 0 分享
查看更多