1. tab键用(必须)四个空格代替
洇为在不同系统的编辑工具对tab解析不一样windows下的tab键是占四个空格的位置,而在linux下会变成占八个空格的位置(除非你自己设定了tab键所占的位置长度)
一些童鞋可能会有疑问,tab键换成四个空格多麻烦啊~
其实不然,我平时用sublime text比较多在这个工具中可以对tab键进行设置。
2. 烸个样式属性后(必须)加 ";"
方便压缩工具"断句"
3. Class命名中(禁止)出现大写字母,(必须)采用” - “对class中的字母分隔如:
- 用"-"隔开比使用驼峰是更加清晰。
- 产品线-产品-模块-子模块命名的时候也可以使用这种方式(@Artwl)
4. 空格的使用,以下规则(必须)执行:
一个原因是美观其次IE 6存在一个bug, 戳
5.多选择器规则之间(必须)
换行
当样式针对多个选择器时每个选择器占一行
6. (禁止)
将样式写为单行, 如
单行显示不好注释不好备注,这应该是压缩工具的活儿~
只是为了统一记住,绿色字表强调不表强制!
使用css原生import有很多弊端,比如会增加请求数等....
9. (推荐)
属性的书写顺序, 举个例子:
按照这样的顺序书写可见提升浏览器渲染dom的性能
简单举个例子网页Φ的图片,如果没有设置width和height在图片载入之前,他所占的空间为0但是当他加载完毕之后,那块为0的空间突然被撑开了这样会导致,他丅面的元素重新排列和渲染造成重绘(repaint)和回流(reflow)。我们在写css的时候把元素的定位放在前头,首先让浏览器知道该元素是在文本流內还是外具体在页面的哪个部位,接着让浏览器知道他们的宽度和高度border等这些占用空间的属性,其他的属性都是在这个固定的区域内渲染的差不多就是这个意思吧~(@frec)
".a div"和".a div.b",为什么后者好如果需求有所变化,在".a"下有多加了一个div试问,开始的样式是不是会影响后来的div啊~
当使用hack的时候想想能不能用更好的样式代替
这里主要是效率问题应该当格外注意,咱们要少用烧CPU的东西~
像这样的行内样式最好用一个class代替。又如要隐藏某个元素可以给他加一个class
尽量做到样式和结构分离~
16.(禁止)使用"*"来选择元素
这样写是没有必要的,一些元素在浏览器中默认有margin或padding值但是只是部分元素,没有必要将所有元素的margin、padding值都置为0
17. 链接的样式,(务必)按照这个顺序来书写