css代码优化的12个技巧

 编写好的CSS代码,有助提升页面的渲染速度。本质上,引擎需要解析的CSS规则越少,性能越好。MDN上将CSS选择符归类成四个主要类别,如下所示,性能依次降低

1.ID 规则
2.Class 规则
3.标签规则
4.通用规则
对效率的普遍认识是从Steve Souders在2009年出版的《高性能网站建设进阶指南》开始,虽然该书中罗列的更加详细,但你也可以在这里查看完整的引用列表,也可以在谷歌的《高效CSS选择器的最佳实践》中查看更多的细节。
本文我想分享一些我在编写高性能CSS中用到的简单例子和指南。这些都是受到MDN 编写的高效CSS指南的启发,并遵循类似的格式。
 
一、避免过度约束
 
 一条普遍规则,不要添加不必要的约束。
 
 代码如下:
 // 糟糕
ul#someid {..}
.menu#otherid{..}
 
// 好的
#someid {..}
#otherid {..}
 
 
二、后代选择符最烂
 
不仅性能低下而且代码很脆弱,html代码和css代码严重耦合,html代码结构发生变化时,CSS也得修改,这是多么糟糕,特别是在大公司里,写html和css的往往不是同一个人。
 
 代码如下:
// 烂透了
html div tr td {..}
 
 
三、避免链式(交集)选择符
 
这和过度约束的情况类似,更明智的做法是简单的创建一个新的CSS类选择符。
 
代码如下:
// 糟糕
.menu.left.icon {..}
 
// 好的
.menu-left-icon {..}
 
 
四、坚持KISS原则
 
想象我们有如下的DOM:
代码如下:
<ul id="navigator">
    <li><a href="#" class="twitter">Twitter</a></li>
    <li><a href="#" class="facebook">Facebook</a></li>
    <li><a href="#" class="dribble">Dribbble</a></li>
</ul>
 
 
下面是对应的规则……
 
代码如下:
// 糟糕
#navigator li a {..}
 
// 好的
#navigator {..}
 
 
五、使用复合(紧凑)语法
 
尽可能使用复合语法。
 代码如下:
// 糟糕
.someclass {
 padding-top: 20px;
 padding-bottom: 20px;
 padding-left: 10px;
 padding-right: 10px;
 background: #000;
 background-image: url(../imgs/carrot.png);
 background-position: bottom;
 background-repeat: repeat-x;
}
 
// 好的
.someclass {
 padding: 20px 10px 20px 10px;
 background: #000 url(../imgs/carrot.png) repeat-x bottom;
}
 
 
六、避免不必要的命名空间
 
 
 代码如下:
// 糟糕
.someclass table tr.otherclass td.somerule {..}
 
//好的
.someclass .otherclass td.somerule {..}
 
 
七、避免不必要的重复
 
尽可能组合重复的规则。
 
 代码如下:
// 糟糕
 
.someclass {
 color: red;
 background: blue;
 font-size: 15px;
}
 
.otherclass {
 color: red;
 background: blue;
 font-size: 15px;
}
 
// 好的
 
.someclass, .otherclass {
 color: red;
 background: blue;
 font-size: 15px;
}
 
八、尽可能精简规则
在上面规则的基础上,你可以进一步合并不同类里的重复的规则。
 代码如下:
// 糟糕
.someclass {
 color: red;
 background: blue;
 height: 150px;
 width: 150px;
 font-size: 16px;
}
 
.otherclass {
 color: red;
 background: blue;
 height: 150px;
 width: 150px;
 font-size: 8px;
}
 
// 好的
.someclass, .otherclass {
 color: red;
 background: blue;
 height: 150px;
 width: 150px;
}
 
.someclass {
 font-size: 16px;
}
 
.otherclass {
 font-size: 8px;
}
 
九、避免不明确的命名约定
最好使用表示语义的名字。一个好的CSS类名应描述它是什么而不是它像什么。
十、避免 !importants
其实你应该也可以使用其他优质的选择器。
 
十一、遵循一个标准的声明顺序
 
虽然有一些排列CSS属性顺序常见的方式,下面是我遵循的一种流行方式。
 代码如下:
.someclass {
 /* Positioning */
 /* Display & Box Model */
 /* Background and typography styles */
 /* Transitions */
 /* Other */
}
十二、组织好的代码格式
代码的易读性和易维护性成正比。下面是我遵循的格式化方法。
代码如下:
// 糟糕
.someclass-a, .someclass-b, .someclass-c, .someclass-d {
 ...
}
 
// 好的
.someclass-a, 
.someclass-b, 
.someclass-c, 
.someclass-d {
 ...
}
 
// 好的做法
.someclass {
    background-image:
        linear-gradient(#000, #ccc),
        linear-gradient(#ccc, #ddd);
    box-shadow:
        2px 2px 2px #000,
        1px 4px 1px 1px #ddd inset;
}
 
 
显然,这里只讲述了少数的规则,是我在我自己的CSS中,本着更高效和更易维护性而尝试遵循的规则。如果你想阅读更多的知识,我建议阅读MDN上的编写高效的CSS和谷歌的优化浏览器渲染指南。

时间: 2024-09-19 09:10:23

css代码优化的12个技巧的相关文章

css代码优化的12个技巧_经验交流

1.ID 规则2.Class 规则3.标签规则4.通用规则对效率的普遍认识是从Steve Souders在2009年出版的<高性能网站建设进阶指南>开始,虽然该书中罗列的更加详细,但你也可以在这里查看完整的引用列表,也可以在谷歌的<高效CSS选择器的最佳实践>中查看更多的细节.本文我想分享一些我在编写高性能CSS中用到的简单例子和指南.这些都是受到MDN 编写的高效CSS指南的启发,并遵循类似的格式. 一.避免过度约束  一条普遍规则,不要添加不必要的约束. 复制代码 代码如下:

最常用的12种CSS BUG解决方法与技巧

最常用的12种CSS BUG解决方法与技巧 一. 针对浏览器的选择器 这些选择器在你需要针对某款浏览器进行css设计时将非常有用. IE6及其更低版本 * html {} IE7及其更低版本 *:first-child+html {} * html {} 仅针对IE7 *:first-child+html {} IE7和当代浏览器 html>body{} 仅当代浏览器(IE7不适用) html>/**/body{} Opera9及其更低版本 html:first-child {} Safari

告诉CSS新手20个小技巧

感谢有了CSS,真是由于她的灵活性,网页的样式可以完全与代码分离.现在,你仅仅需要有CSS的基础知识,甚至是一个初学者也能够轻易的改变网站的外观. 在过去,我们大量依靠网站设计人员和程序员来帮忙更新网站,甚至一个十分简单的网页也是如此.感谢有了CSS,真是由于她的灵活性,网页的样式可以完全与代码分离.现在,你仅仅需要有CSS的基础知识,甚至是一个初学者也能够轻易的改变网站的外观. 无论你是准备用CSS来创建你自己的网页,还是仅仅想用她来改变你博客的外观,学习CSS基本原则都有助于为你打下CSS的

常用的10种CSS BUG解决方法与技巧

最常用的10种CSS BUG解决方法与技巧-浏览器兼容教程 CSS bug是布局中最头疼的问题.我们需要兼顾各种浏览器,以期待获得一致的效果. 非常遗憾的是各厂商之间的竞争导致很多问题的存在.而IE6与IE7在很多问题上也存在着很大的差别. 轻松的解决CSS bug是我们必须掌握的技能.现在整理出最常用的12种CSS BUG解决方法以及CSS BUG类的小技巧. 希望对您的学习.工作有所帮助,如果您依然有疑问, 一. 针对浏览器的选择器 这些选择器在你需要针对某款浏览器进行css设计时将非常有用

创建CSS样式表的十个技巧

  如果你想成为一位CSS专家的话,光背出一堆选择器是不够的,还要能够提高CSS样式表的可读性,开发效率以及维护性.这里,Jina Bolton 将给我们分享一下她关于如何创建性感的CSS样式表的十个技巧. 本文主要内容为:CSS代码编码规范,教你如何写出整洁漂亮性感的css代码,如何清晰的组织你的样式表文件.闲言少叙,直接进入正题 1. 不要在HTML文件中使用CSS样式定义 相信对于多数有一定工作经验的设计师来说,使用外部样式表来定义CSS样式是小菜一碟的工作.但我在这里仍然需要再次告诉你这

《jQuery、jQuery UI及jQuery Mobile技巧与示例》——9.12 技巧:跨页面时固定footer

9.12 技巧:跨页面时固定footer 点击链接时,在页面发生变化期间会触发动画.有些情形下你并不想让footer成为动画的一部分.代码清单9-14演示了当链接至别的页面时如何将footer保持在同一个地方. 代码清单9-14 当页面发生变化时固定footer 00 <!DOCTYPE html> 01 <html> 02 <head> 03 <title>Fixed Footer</title> 04 <meta name="

Google&amp;nbsp;AdWords广告的12个技巧

google|word|广告|技巧 这篇文章要向大家展示在Google AdWords关键词排名广告中创建成功的广告内容的一些技巧.我已经用这些方法对Google的按点击付费广告服务测试了有一段时间了,结果非常成功.这12个技巧可以帮助你在Google关键词排名广告中创建一个较高的点击率,并以更低的价格排在前面.-正如你所期待的! 1. 锁定正确的目标群体 通过选择某种语言和某个国家或地区来锁定你的潜在客户群体.例如,你可以设定只让你的广告出现在某个特定国家的潜在客户,比如现在有许多讲法语的国家

CSS的十八般技巧

css|技巧 翻译:阿捷 原文作者:Roger Johansson 作者简介:住在瑞典哥德堡,1994年开始接触和参与web设计,456 Berea Street是他的住址,因此采用这个名字作为他的个人主页域名 最近,经常有朋友问我一些工作中遇到的CSS问题.他们总是不能很好的控制CSS,影响CSS的效率发挥.我来分析总结一下错误所在,帮助大家更加容易使用CSS. 本文总结了我开始使用CSS布局方法以来所有的技巧和兼容方案,我愿意把这些与你分享,我会重点解释一些新手容易犯的错误(包括我自己也犯过

《jQuery、jQuery UI及jQuery Mobile技巧与示例》——3.12 技巧:在指定的位置插入元素

3.12 技巧:在指定的位置插入元素 append().appendTo().prepend()和prependTo()函数是以选取已存在的元素为基准插入新内容的.有时候,想新建的元素是兄弟元素而不是子元素.代码清单3-12演示了实现该功能的一种可选方法. 代码清单3-12 在一组按钮之前和之后插入元素 00 <!DOCTYPE html> 01 02 <html lang="en"> 03 <head> 04 <title>The af