墨者,爱, 心情!
墨者學堂

我最近的CSS习惯 

16
December 2008

之前有要求我多写点CSS方面的,那就写吧。因为习惯其实是会变的,所以只能写“最近”的。

这些习惯都跟技术无关,如果不遵守,也不会出错。但是我个人觉得良好的习惯会体现一个人的素质。

1. class_name方式写类名。以前喜欢用class-name写,不过好像两样也没什么差别。但我比较不喜欢用className写类名,因为浏览器对大小写敏感的问题。但是id我会写成驼峰式。

2.样式一般用class而不用id。有三个理由,

一,id不可以重复,而class理论上可以无限制的重复。

二,id的优先级太高,若是写了一个#txt_content a {color:#09c} 的话,那可能会很麻烦,里面要改链接颜色,都必须加上#page_content才能越过这个优先级。

三,id专门留给JavaScript用,这样才符合表现与行为分离的原则。所以id用驼峰式,也是为了体现这一点。

3.margin和padding,尽量简写。比如margin: 20px 10px 5px 10px; ,左右值是一样的,就应该省略掉最后一个值,写成margin: 20px 10px 5px; 这样到时候要改左右间距,改一个就好,免得改漏了。其实这个问题虽然很细小,但是可以看得出对margin四个值省略规则的熟练程度。

还有:

margin: 20px 20px 20px 20px; ==  margin: 20px;

margin: 20px 10px 20px 10px; == margin: 20px 10px;

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:leftdisplay: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{}

缩进,是为了表示它们对应的标签具有父子关系。但这样只能起一个提醒的作用。

vicky:

2008-12-23 10:38
不错

.::

2008-12-24 00:01
看不懂,这是什么语言哦?

.:

2008-12-24 00:01
好像很高深的样子!

Xman:

2009-01-14 00:48
-_-...

dream:

2009-02-16 15:26
请教一下那个湖大的教务系统不排队的怎么打不开了?
谢谢

dfgdfgdfgd:

2009-02-22 21:58
haha d


珊:

2009-04-02 19:40
yi  hou  zai    shuo    

paper:

2009-04-07 18:58
恩,我觉得写的很不错啊。

“样式一般用class而不用id”这个我是深有体会啊.....感谢您!!

“在JS里var a = b   c;里面的空格也应该都要加”这个嘛就那个啥了。我写的时候就不会加空格:var a=b c;
呵呵,如果用aptana写js代码的话,会有一个format功能,它会自动的加上空格的,就不用自己操心了.....

你在长沙工作啊??呵呵,感觉你应该可以在这个行业发展的很好。

paper:

2009-04-07 19:01
哦,顺便说一句,这个发表留言下面的按钮上的“保存”字可不可以改为“提交”啊?刚开始“雷”到我了。呵呵.........

paper:

2009-04-07 19:08
我看过“http://www.hunan.gov.cn/  湖南省政府门户网站”了,那应该不是你的作品吧?--!

我可不可以看看您的作品呢??

(*^__^*) 嘻嘻……

墨者:

2009-04-10 22:49
呵呵,我的是 www.enghunan.gov.cn

提交 VS 保存,呵呵,  

 提交 更像 计算机术语,而  保存 更接近人的语言,
可能我们用计算机久了,习惯了 提交,

 但是对于 很少接触计算机的人,“保存”显得更为恰当,

 呵呵,一家之言了

路过:

2009-05-21 22:17
我顶

路过:

2009-05-21 22:17

 不错

路过:

2009-05-21 22:17

路过:

2009-05-21 22:17
  • 最多十个字
  • 保证不会公开
  • 保存
  •  
  • 王子墨 · Julying
  • 23岁 · 长沙
  • 网页设计师 · Web开发工程师
©2006-2010 Fridaying.Com | All Rights Reserved.