首页 > 开发 > CSS > 正文

渲染CSS选择器

2024-07-11 08:22:14
字体:
来源:转载
供稿:网友

最近在high performance web sites blog看到一篇关于css选择器的文章《simplifying css selectors》,我英文太差,在翻译软件和朋友的帮助下稍微的看懂了一些,看本文需要谨慎,谨防被我误导,如果你英文强,能翻译作者原文那就更好了,大家都会感谢你的;

看懂的整理了如下几点:

1.作者先前的文章里说:不用去优化css选择器,因为优化css选择器对网友的性能提升很小,不值得去计较;这个观点似乎有点不对,作者收到了很多批评的反馈;(转载请注明出处:web前端开发 http://www.css88.com/)

2.david hyatt的文章《writing efficient css for use in the mozilla ui》中提到的一条css渲染规则是:在一条css中,css选择器是从最右边开始之后依次向左移动的,直到它不匹配css规则或匹配错误;所以我们的工作重点应该放在最右侧的css选择器来匹配大量的页面的元素。

比如这样一个css选择器:
div div div p a.class0007 {}
这个选择器有5层,貌似很负责的,但是最右边的选择器是a.class0007,在页面中只有一个匹配的元素逆向匹配(.class0007);

所以这样的选择器不用担心他的性能;

3.当然还有一些性能不好的css选择器:

a.class0007 * {}

a.class0007 div {}

#id0007 > a {}

.class0007 [href] {}

div:first-child {}

这些性能不好的css选择器主要是因为在最右边的选择器可以匹配的元素很多,从而降低了页面的性能。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表