有关CSS样式中ID和class的命名

有关 CSS样式中id与class命名或许大家都没有太在意,以为随意命名就行了,没有那么多讲究。其实这种观点不是一个很好的编程习惯。拥有良好的命名规则更加有样式的可读性等。
  一、用class_name方式来命名类名。

  有些网友喜欢用class-name来命名,不过好像这二个命名没有很大关系。但笔者反对用className写类名,像这样的驼峰命名法在服务器端脚本中可能用的多。但我不建议用在CSS样式上,因为始终对浏览器大小写敏感的问题抱有怀疑态度。但是id建议用驼峰式,详细请继续看下文。

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

  有三个理由来说明这点。

  1,因为id是不可以重复的,唯一的,所以用class的话,可以不顾一切的使用,甚至可以用在每个标签里。

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

  3,id一般是用在便于JS来调用,这样才符合表现与行为分离的原则。所以id建议驼峰式,也是为了体现这一点。

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

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

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

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

  .side_col_webjx {

  float:left;

  display: inline;

  margin-left: 20px;

  }

  而笔者经常会这样来写:

  .side_col_webjx {

  float: left;

  margin-left: 20px;

  }

  * .side_col_webjx {

  _display:inline;   /*兼容 IE 6*/

  }

  不应该把hack混在一起,也不应该用一种侥幸的心态,觉得float:left与display:inline写在一起没事。嗯,它们俩确实没事儿,但是其他的hack就不一定了。而且这里写display:inline纯粹就是为了解决IE6的bug,所以前面加上下划线,以明确的表达你的目的。 
      我喜欢在hack前面加上星号,其实这纯粹是个人习惯了。可能过段时间我就不这么用了,呵呵。

  最后,不要以为所有的hack都是为IE准备的。其实有些hack是针对其他浏览器的,像火狐等。这就要求你对css标准的熟练掌握,能够自信的判断哪些渲染是遵守标准,哪些违反标准的。

  五、千万记得要加空格。

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

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

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

  .nav .search {}

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

  .login_box {}

  .forgot_pwd{}

  缩进,是为了表示它们对应的标签具有父子关系。这样不仅起到了提醒的作用,更有利于代码的可读性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值