由于本身最近写css用的比较多仍是less,整理了一份less规范, css
代码按以下形式按顺序组织:web
@import
1 // ✓ 2 @import "est/all.less"; 3 4 @default-text-color: #333; 5 6 .page { 7 width: 960px; 8 margin: 0 auto; 9 }
@import
语句@import
语句引用的文件写在一对引号内,.less
后缀不省略(与引入 CSS 文件时的路径格式一致)。引号使用 '
和 "
都可。less
// ✗
@import 'est/all';
@import "my/mixins.less";
// ✓
@import "est/all.less";
@import "my/mixins.less";
选择器和 {
之间保留一个空格。ide
属性名后的冒号(:
)与属性值之间保留一个空格,冒号前不保留空格。函数
定义变量时冒号(:
)与变量值之间保留一个空格,冒号前不保留空格。编码
在用逗号(,
)分隔的列表(Less 函数参数列表、以 ,
分隔的属性值等)中,逗号后保留一个空格,逗号前不保留空格。spa
// ✗ .box{ @w:50px; @h :30px; width:@w; height :@h; color: rgba(255,255,255,.3); transition: width 1s,height 3s; } // ✓ .box { @w: 50px; @h: 30px; width: @w; height: @h; transition: width 1s, height 3s; }
运算
+
/ -
/ *
/ /
四个运算符两侧保留一个空格。+
/ -
两侧的操做数有相同的单位,若是其中一个是变量,另外一个数值书写单位。code
// ✗
@a: 200px;
@b: (@a+100)*2;
// ✓
@a: 200px;
@b: (@a + 100px) * 2;
Mixin 和后面的空格之间不包含空格。在给 mixin 传递参数时,在参数分隔符(,
/ ;
)后保留一个空格:orm
// ✗ .box { .size(30px,20px); .clearfix (); } // ✓ .box { .size(30px, 20px); .clearfix(); }
当多个选择器共享一个声明块时,每一个选择器声明独占一行。xml
// ✗ h1, h2, h3 { font-weight: 700; } // ✓ h1, h2, h3 { font-weight: 700; }
Class 命名不得以样式信息进行描述,如 .float-right
、text-red
等。
多个属性定义能够使用缩写时, 尽可能使用缩写。缩写更清晰字节数更少。常见缩写有 margin
、border
、padding
、font
、list-style
等。在书写时考量缩写展开后是否有不须要覆盖的属性内容被修改,从而带来反作用。
对于处于 (0, 1)
范围内的数值,小数点前的 0
能够(MAY)省略,同一项目中保持一致。
// ✗
transition-duration: 0.5s, .7s;
// ✓
transition-duration: .5s, .7s;
当属性值为 0 时,省略可省的单位(长度单位如 px
、em
,不包括时间、角度等如 s
、deg
)。
// ✗
margin-top: 0px;
// ✓
margin-top: 0;
颜色定义使用 #rrggbb
格式定义,并在可能时尽可能缩写为 #rgb
形式,且避免直接使用颜色名称与 rgb()
表达式。
// ✗
border-color: red;
color: rgb(254, 254, 254);
// ✓
border-color: #f00;
color: #fefefe;
同一属性有不一样私有前缀的,尽可能(按前缀长度降序书写,标准形式写在最后。且这一组属性以第一条的位置为准,尽可能按冒号的位置对齐。
// ✓ .box { -webkit-transform: rotate(30deg); -moz-transform: rotate(30deg); -ms-transform: rotate(30deg); -o-transform: rotate(30deg); transform: rotate(30deg); }
能够在无其余更好解决办法时使用 CSS hack,而且尽可能使用简单的属性名 hack 如 _zoom
、*margin
。
能够但谨慎使用 IE 滤镜。须要注意的是,IE 滤镜中图片的 URL 是以页面路径做为相对目录,而不是 CSS 文件路径。
嵌套的声明块前增长一次缩进,有多个声明块共享命名空间时尽可能嵌套书写,避免选择器的重复。
可是需注意的是,尽可能仅在必须区分上下文时才引入嵌套关系(在嵌套书写前先考虑若是不能嵌套,会如何书写选择器)。
// ✗ .main .title { font-weight: 700; } .main .content { line-height: 1.5; } .main { .warning { font-weight: 700; } .comment-form { #comment:invalid { color: red; } } } // ✓ .main { .title { font-weight: 700; } .content { line-height: 1.5; } .warning { font-weight: 700; } } #comment:invalid { color: red; }
Less 的变量值老是以同一做用域下最后一个同名变量为准,务必注意后面的设定会覆盖全部以前的设定。
变量命名)采用 @foo-bar
形式,不使用 @fooBar
形式。
// ✗
@sidebarWidth: 200px;
@width:800px;
// ✓
@sidebar-width: 200px;
@width: 800px;
使用继承时,若是在声明块内书写 :extend
语句,写在开头:
// ✗ .sub { color: red; &:extend(.mod all); } // ✓ .sub { &:extend(.mod all); color: red; }
在定义 mixin 时,若是 mixin 名称不是一个须要使用的 className,加上括号,不然即便不被调用也会输出到 CSS 中。
// ✗ .big-text { font-size: 2em; } h3 { .big-text; } // ✓ .big-text() { font-size: 2em; } h3 { .big-text(); }
若是混入的是自己不输出内容的 mixin,在 mixin 后添加括号(即便不传参数),以区分这是不是一个 className(修改之后是否会影响 HTML)。
// ✗ .box { .clearfix; .size (20px); } // ✓ .box { .clearfix(); .size(20px); }
Mixin 的参数分隔符使用 ,
和 ;
都可,但在同一项目中保持统一。
变量和 mixin 在命名时遵循以下原则:
在进行字符串转义时,使用 ~""
表达式与 e()
函数都可,但在同一项目中保持一致。
字符串两侧的引号使用 "
。
单行注释尽可能(SHOULD)使用 //
方式。
// Hide everything * { display: none; }