一种有创意的CSS命名规则

作者:dudo 来源:dudo blog 时间:2008-06-15 15:18:00 

关于CSS中的命名规则(其实我觉得是XHTML元素的命名规则更加合理些)这个问题,已经有很多人在说了,其中也不乏一些真知灼见。不过这种东西也是仁者见仁,智者见智,只要一个团队有统一的命名规则要求,在日常开发和维护中不至于出现混乱就应该说是好的命名规则。比如下面这条基本的命名规则:

外 套wrap主导航mainnav子导航subnav
 页 脚 footer 整个页面 content 页 眉 header
 商 标 label 标 题 title 顶导航 topnav
 边导航 sidebar 左导航 leftsidebar 右导航 rightsidebar
 旗 志 logo 标 语 banner 子菜单 submenu
 容器 container 内容 content 当前的 current

CSS开发命名规则

问题是,上面的诸如leftsidebar,rightsidebar等拥有很强指向性的命名在以后的布局变化中会怎么样呢?如果left出现的位置不是左侧,是中间或者是右侧怎么办呢?如果rightsidebar出现在左侧怎么办呢?这时的命名似乎有点不合逻辑了。有人常和我说,你这样的考虑有意义吗?多余的!真正有几个网站会用同样的结构去做两次不一样的布局,顶多就是改版了,改版的时候连结构都变了,这样的考虑完全多余。的确,经常会有这样的问题,有些网站不一次成形到下次改版前风格基本上不会改变,但是有些网站,比如我的博客,你再去看看PJBlog的官方博客,同样的结构却有截然不同的表现。

看下面的代码:

<div>  
  <div>content</div>  
  <div>bar1</div>  
  <div>bar2</div>  
</div>  

怎么去命名他们呢?bar1和bar2可以出现在两侧,也可能出现在一侧,无论使用right、left、middle都不太合适。那么怎么去命名会比较合适一点呢?

这里提供一个来自Adobe.com的创意,它使用的是 父元素-栏目组-栏目,其中栏目(column)使用无实际意义的字符表示,如A、B、C等。例如 wrap-AB-A,意思已经ID为wrap的元素下包含着两个div——A和B,现在要进行操作的是A。这样的命名完全和元素没有关系,而且意义还比较清晰。例如上面的命名就可以写成:

<div id="container">  
  <div id="container_ABC_A">content</div>  
  <div id="container_ABC_A">bar1</div>  
  <div id="container_ABC_A">bar2</div>  
</div>  

"container_ABC_A",说明是对container下有三个并列的元素(它们的ID分别是A、B、C),目前指向的是第一个,即A。这样做的好处就是不受布局的影响,名称和页面最终表现想分离,不过一个缺点就是,下因为A、B、C的意义使得再次嵌套的时候命名有点“乱”,如 id="container_ABC_A_abc_a",层次深了就不太清晰了。

个人感觉这样的命名比较新颖,非常值得借鉴。不过正如一开始所说的,“只要一个团队有统一的命名规则要求,在日常开发和维护中不至于出现混乱就应该说是好的命名规则”。

标签:命名,规则,css,创意
0
投稿

猜你喜欢

  • 恢复master..xp_logattach(log explorer)

    2010-07-01 19:19:00
  • 网马解密大讲堂——网马解密中级篇(Freshow工具使用方法)

    2009-09-16 15:09:00
  • asp中如何过滤到单引号

    2009-07-05 18:38:00
  • asp如何用FileSystemObject组件来做一个站内搜索?

    2010-06-12 12:47:00
  • ASP codepage 页面编码使用说明

    2011-03-03 11:24:00
  • HTML与javascript中常用编码浅析

    2008-12-23 12:20:00
  • Web Design广告字体设计技巧

    2010-06-24 21:52:00
  • 获得当前数据库对象依赖关系的实用算法

    2009-01-08 13:28:00
  • getWindow与isWindow

    2009-12-28 13:12:00
  • 间歇向上无缝翻滚代码

    2008-05-05 12:30:00
  • IE对CSS样式表的限制和解决方案

    2008-04-28 12:27:00
  • 内容,而不是Chrome

    2008-10-16 13:43:00
  • 你需要知道的CSS3 动画技术[译]

    2009-12-30 17:02:00
  • CSS Sprites + 圆角[译]

    2009-05-08 16:10:00
  • ASP开发的WAP格式简易邮件系统实例

    2008-06-10 17:00:00
  • 正则表达式语法速查

    2007-11-11 10:43:00
  • 奇淫技巧和西天取经

    2009-08-24 12:34:00
  • 用来武装Firefox的24款Web开发插件

    2010-02-28 12:40:00
  • 使用 JSON 进行数据传输

    2008-06-15 07:12:00
  • 关于web标准的思考

    2008-10-05 10:07:00
  • asp之家 网络编程 m.aspxhome.com