css选择器的渲染性能
时间:2009年06月22日作者:愚人码头查看次数:5,465 views评论次数:2
最近在High Performance Web Sites blog看到一篇关于css选择器的文章《Simplifying CSS Selectors》,我英文太差,在翻译软件和朋友的帮助下稍微的看懂了一些,看本文需要谨慎,谨防被我误导,如果你英文强,能翻译作者原文那就更好了,大家都会感谢你的;
看懂的整理了如下几点:
1.作者先前的文章里说:不用去优化CSS选择器,因为优化CSS选择器对网友的性能提升很小,不值得去计较;这个观点似乎有点不对,作者收到了很多批评的反馈;
2.David Hyatt的文章《Writing Efficient CSS for use in the Mozilla UI》中提到的一条CSS渲染规则是:在一条css中,css选择器是从最右边开始之后依次向左移动的,直到它不匹配CSS规则或匹配错误;所以我们的工作重点应该放在最右侧的CSS选择器来匹配大量的页面的元素。
比如这样一个css选择器:
1 | div div div p a.class0007 {} |
这个选择器有5层,貌似很负责的,但是最右边的选择器是A.class0007,在页面中只有一个匹配的元素逆向匹配(.class0007);
所以这样的选择器不用担心他的性能;
3.当然还有一些性能不好的css选择器:
1 | A.class0007 * {} |
1 | A.class0007 DIV {} |
1 | #id0007 > A {} |
1 | .class0007 [href] {} |
1 | DIV:first-child {} |
这些性能不好的css选择器主要是因为在最右边的选择器可以匹配的元素很多,从而降低了页面的性能。
如果你的英文好,最好看原文,防止被我误导。最好能翻译成中文,共享!
声明: 本文采用 BY-NC-SA 协议进行授权 | WEB前端开发
转载请注明转自《css选择器的渲染性能》



我翻译了
http://www.99css.com/2009/06/simplifying-css-selectors.html
建议先看下面这篇再看上面的,两个有关联
http://www.99css.com/2009/06/performance-impact-of-css-selectors.html
[回复]
不错的文章,正在拜读。
[回复]