CSS中id与class命名规则及编码最佳习惯

开发 前端
你对CSS中id与class命名及编码的6个最佳习惯是否了解,这里和大家分享一下,通常情况下用class_name方式写类名,并且样式都用class而不用id。

CSS网页布局有很多值得学习的地方,这里和大家重点讨论一下CSS中id与class命名及编码的6个最佳习惯,相信本文介绍一定会让你有所收获。

CSS中id与class命名及编码的6个最佳习惯

关于CSS网页布局id与class命名或许成为大家比较头疼的问题,在51cto.com中早已有相关的介绍,但还是不能满足大家对知识的渴求。
  
一、用class_name方式写类名。

  以前喜欢用class-name写,不过好像两样也没什么差别。但我比较反对用className写类名,因为始终对浏览器大小写敏感的问题抱有怀疑态度。但是id我会写成驼峰式,理由见下一条。

二、样式都用class而不用id。

  有三个理由。

  1,id不可以重复,所以用class的话,可以肆无忌惮的用无数次。

  2,id的优先级太高,若是写了一个#page_contenta{color:#f60},那你完蛋了,里面要改链接颜色,都必须加上#page_content才能越过这个优先级。

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

三、margin和padding,尽量省略最后一个值。

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

四、按标准写css,再针对特定浏览器作hack。

  比如,通常我们会遇到如下的写法:

ExampleSourceCode

  1. .side_col_52CSS{  
  2. float:left;  
  3. display:inline;  
  4. margin-left:20px;  
  5. }  
  6.  

  而我的写法会是:

ExampleSourceCode

  1. .side_col_52CSS{  
  2. float:left;  
  3. margin-left:20px;  
  4. }  
  5. *.side_col_52CSS{  
  6. _display:inline;/*hackedforIE6*/  
  7. }  
  8.  

  看明白了么?不应该把hack混在一起,也不应该用一种侥幸的心态,觉得float:left与display:inline写在一起没事。嗯,它们俩确实没事儿,但是其他的hack就不一定了。而且这里写display:inline纯粹就是为了解决IE6的bug,所以前面加上下划线,以明确的表达你的目的。

  另外不要以为凡是hack都是为IE准备的。其实有些hack是针对其他浏览器的,比如FF。这就要求你对css标准的熟练掌握,能够自信的判断哪些渲染是遵守标准,哪些违反标准的。
  此外,我喜欢在hack前面加上星号,其实这纯粹是个人习惯了。可能过段时间我就不这么用了,呵呵。

五、记得加空格。

  .class_name{property:value;}。我个人觉得合理的空格是优秀代码的一个指标。按英文的习惯,标点后面都应该带空格(如果你写Thisisapen.That’sapencil.句点后面不加空格,word里面会有错误提示)。所以既然css是外国人发明的,应该按他们的格式来写。类似的,在JS里vara=b+c;里面的空格也应该都要加。

六、适当的层叠(Cascading)或缩进以定义css的“作用域”。

  什么是“css的作用域”?其实并不是所有的样式都在所有的地方使用。有的样式只用在某一块里面,比如“导航栏”里的“搜索框”,可能应该写成:

ExampleSourceCode

  1. .nav.search{}  
  2.  

  而有时候用层叠会增加代码优先级,所以也可以用缩进来“象征性的”体现作用域。像这样:

ExampleSourceCode

  1. .login_box{}  
  2. .forgot_pwd{}  
  3.  

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

【编辑推荐】

  1. CSS clip属性用法详解
  2. CSS3八大新功能闪亮登场
  3. 专家推荐三大“顶级”CSS技巧!
  4. 编写完美CSS代码的五个关键
  5. CSS水平居中和垂直居中多种解决方案
责任编辑:佚名 来源: 52css.com
相关推荐

2010-08-27 09:51:25

idclassCSS

2010-09-14 15:24:49

CSSIDClass

2010-08-24 15:20:02

CSSidclass

2010-09-03 09:46:50

idclassCSS

2009-03-11 10:06:42

C#3.0编码习惯命名规则

2010-08-30 10:52:39

CSSclassid

2010-09-08 16:49:05

CSSclassid

2010-08-23 10:57:14

CSSclassid

2010-09-01 12:43:47

CSSidclass

2010-09-03 16:16:23

CSSidclass

2010-08-27 08:53:18

CSS类id命名DIV

2010-09-08 15:44:17

CSSidclass

2010-09-10 10:42:07

idclassDIV CSS

2010-08-16 12:54:53

DIVCSS

2010-08-23 14:16:17

DIVclassid

2010-09-02 12:54:30

CSS

2010-08-25 09:11:57

DIVCSS

2010-08-30 10:46:13

DIV+CSS

2010-09-07 15:53:02

CSS规范化

2010-09-02 16:26:59

CSS命名
点赞
收藏

51CTO技术栈公众号