之前有要求我多写点CSS方面的,那就写吧。因为习惯其实是会变的,所以只能写“最近”的。这些习惯都跟技术无关,如果不遵守,也不会出错。但是我觉得良好的习惯会体现一个人的素质。
1. 用class_name方式写类名。以前喜欢用class-name写,不过好像两样也没什么差别。但我比较反对用className写类名,因为始终对浏览器大小写敏感的问题抱有怀疑态度。但是id我会写成驼峰式,理由见下一条。
2.样式都用class而不用id。有三个理由,一,id不可以重复,所以用class的话,可以肆无忌惮的用无数次。二,id的优先级太高,若是写了一个#page_content a {color:#f60} ,那你完蛋了,里面要改链接颜色,都必须加上#page_content才能越过这个优先级。三,id专门留给JS用,这样才符合表现与行为分离的原则。所以id我用驼峰式,也是为了体现这一点。
3.margin和padding,尽量省略最后一个值。比如margin: 20px 10px 5px 10px; ,左右值是一样的,就应该省略掉最后一个值,写成margin: 20px 10px 5px; 这样到时候要改左右间距,改一个就好,免得改漏了。其实这个问题虽然很细小,但是可以看得出对margin四个值省略规则的熟练程度。
4.按标准写CSS,再针对特定浏览器作hack。比如,通常我们会遇到如下的写法:
.side_col {
float:left;
display: inline;
margin-left: 20px;
}
而我的写法会是:
.side_col {
float: left;
margin-left: 20px;
}
* .side_col {
_display:inline; /*hacked for IE 6*/
}
看明白了么?不应该把hack混在一起,也不应该用一种侥幸的心态,觉得float:left与display:inline写在一起没事。嗯,它们俩确实没事儿,但是其他的hack就不一定了。而且这里写display:inline纯粹就是为了解决IE6的bug,所以前面加上下划线,以明确的表达你的目的。
另外不要以为凡是hack都是为IE准备的。其实有些hack是针对其他浏览器的,比如FF。这就要求你对CSS标准的熟练掌握,能够自信的判断哪些渲染是遵守标准,哪些违反标准的。
此外,我喜欢在hack前面加上星号,其实这纯粹是个人习惯了。可能过段时间我就不这么用了,呵呵。
5. 记得加空格。.class_name { property: value; } 。我个人觉得合理的空格是优秀代码的一个指标。按英文的习惯,标点后面都应该带空格(如果你写This is a pen.That’s a pencil.句点后面不加空格, word里面会有错误提示)。所以既然CSS是外国人发明的,应该按他们的格式来写。类似的,在JS里var a = b + c;里面的空格也应该都要加。
6.适当的层叠(Cascading)或缩进以定义CSS的“作用域”。啥叫“CSS的作用域”?其实并不是所有的样式都在所有的地方使用。有的样式只用在某一块里面,比如“导航栏”里的“搜索框”,可能应该写成:
.nav .search {}
而有时候用层叠会增加代码优先级,所以也可以用缩进来“象征性的”体现作用域。像这样:
.login_box {}
.forgot_pwd{}
缩进,是为了表示它们对应的标签具有父子关系。但这样只能起一个提醒的作用。
大仙: 2008-12-14 11:26 pm
终于又学到了不少东西,特别那个空格,我之前总是没有加空格,以后得改正才行。
感觉搞前端的要懂好多喔,不紧是设计整站的效果,也就是要懂PS,还要懂CSS,还要懂那个js等等。
willerce: 2008-12-15 12:45 am
学习了。
圆峰: 2008-12-15 3:17 pm
空格我还是不喜欢加,少一个字节是个字节
小麦: 2008-12-15 11:59 pm
事实上,我最后上线之前会把CSS全部压缩,去掉所有的空格缩进和注释。
song: 2008-12-16 11:41 am
w3c推荐 class命名中不要有下划线
我以前习惯用class_name,现在改用class-name了
而且在很多编辑器中,比如emacs,用class_name还不能语法高亮,因为这是一个非法的命名。
小麦: 2008-12-16 3:28 pm
哦是么?哪里有写?
大仙: 2008-12-16 6:28 pm
缩进那里没有看明白。
smoke520: 2008-12-16 10:38 pm
和我平时写ccs的风格很像啊,不过我class名字的写法还是习惯驼峰式。
jacksuc: 2008-12-16 10:53 pm
空格啊?我原来以为不加空格为好来呢。呵呵。原来错了。学习了!!
hax: 2008-12-24 10:39 pm
不推荐下划线是因为早期CSS1规范的语法定义有bug,下划线变成非法字符了。有些死心眼的浏览器看到下划线就会出问题。不过现在的主流浏览器都没有这个毛病。
小麦: 2008-12-27 11:43 pm
嗯,这我倒是有在某本书上看到过。
myfuture_wj: 2009-1-5 10:11 pm
初学者,学习,请多指教。
元云: 2009-2-11 9:36 am
其实,兼容所有5大主流浏览器可以不用到hack 的
….实在不提倡使用hack!
;)
辉舞世间: 2009-12-7 2:57 pm
我在刚开始写CSS时都是
.side_col {
float: left;
margin-left: 20px;
}
这种形式写的!
现在都改成.side_col { float: left; margin-left: 20px;}这种形式了,想问问这两种书写形式有什么不同和优缺点!!
lisfan: 2010-1-1 9:17 pm
看各人的习惯吧,我采取横向的,
竖向时只要将眼定在代码区域,同时就能清晰的看到下一行的CSS代码,而横向不会,只会有一种模糊感,可能只看到一半,这样做,只是想让自己将视线转移到下一个之前,能想清楚上一个表达的样式。
总之,还是个人习惯,喜好问题