一直以来,书写css都是率性所为,没有遵循一定的规范;俗话说:没有规矩,不成方圆。造成了代码可读性极差,导致了网站后期维护非常困难。

一、书写顺序

属性
定位position z-index display left right top bottom clip
尺寸width height min-height max-height min-width max-width
文字color font-size letter-spacing, color- text-align等
背景background-image border等
其他animation, transition等
/* bad */
.example {
    color: red;
    z-index: -1;
    background-color: #9e0;
    display: inline-block;
    font-size: 1.5em;
}

/* good */
.example {
    z-index: -1;
    display: inline-block;
    font-size: 1.5em;
    background-color: #9e0;
}

二、一些注意事项

能缩写的尽量缩写

例如:background-color:#333;background-image: url(skin/p_103x196_1.jpg); background-repeat: repeat-x;

改为:background:url(skin/p_103x196_1.jpg) repeat-x #333;

/* bad */
.example {
    border-top-style: none;
    font-family: serif;
    font-size: 100%;
    line-height: 1.6;
    padding-bottom: 2em;
    padding-left: 1em;
    padding-right: 1em;
    paddiing-top: 0;
}

/* good */
.example {
    border-top: 0;
    font: 100%/1.6 serif;
    padding: 0 1em 2em;
}

能少些尽量少写

例如:font-size:0.9em 可以写为:font-size:.9em

灰度值可以缩写的缩写

例如:color:#666666; 可以写为:color:#666;

在别人阅读代码可以看得多的情况下缩写

例如:navigation 可以写为 nav

不建议使用_下划线来命名CSS选择器

原因:

  1. 输入的时候少按一个shift键
  2. 浏览器兼容问题 (比如炼独使用_tips的选择器命名,在IE6是无效的)
  3. 能良好区分JavaScript变量命名(JS变量命名是用_)

二、CSS命名规范(常用的CSS命名规则)

名称命名
header
内容content/container
footer
导航nav
侧栏sidebar
栏目column
页面外围控制整体佈局宽度wrapper
左右中left right center
登录条loginbar
标志logo
广告banner
页面主体main
热点hot
新闻news
下载download
子导航subnav
菜单menu
子菜单submenu
搜索search
友情链接friendlink
页脚footer
版权copyright
滚动scroll
内容content
标签tags
文章列表list
提示信息msg
小技巧tips
栏目标题title
加入joinus
指南guide
服务service
注册regsiter
状态status
投票vote
合作伙伴partner

三、css文件中注释的写法

注释的写法

/* Header */
内容区
/* End Header */

ID的命名

页面结构命名
容器container
页头header
内容content/container
页面主体main
页尾footer
导航nav
侧栏sidebar
栏目column
页面外围控制整体佈局宽度wrapper
左右中left right center

CSS样式表文件命名

主要的master.css
模块module.css
基本共用base.css
版面layout.css
主题themes.css
专栏columns.css
文字font.css
表单forms.css
补丁mend.css
打印print.css