LESS
Less 是一门 CSS 预处理语言,它扩展了 CSS 语言,增加了变量、Mixin、函数等特性,使 CSS 更易维护和扩展。
Less 可以运行在 Node 或浏览器端。
更详细的用法请阅读 LESS 官网文档:DOCUMENTATION
团队约定
虽然CSS预处理语言有LESS/SASS/STYLUS等等,但考虑到 Ant Design Vue官方组件使用的是Less, 为保持代码一致性,请在项目只使用Less进行样式代码编写
编码
使用UTF-8编码。不得(MUST NOT)包含BOM信息。
代码组织
代码必须(MUST)按如下形式按顺序组织:
@import
变量声明
样式声明
@import"est/all.less"; |
@import
语句@import
语句引用的文件必须(MUST)写在一对引号内,.less
后缀不得(MUST NOT)省略(与引入 CSS 文件时的路径格式一致)。引号使用 '
和 "
均可,但在同一项目内必须(MUST)统一。
正例:
@import"est/all.less"; |
反例:
@import'est/all'; |
空格
属性、变量
选择器和 {
之间必须(MUST)保留一个空格。
属性名后的冒号(:
)与属性值之间必须(MUST)保留一个空格,冒号前不得(MUST NOT)保留空格。
定义变量时冒号(:
)与变量值之间必须(MUST)保留一个空格,冒号前不得(MUST NOT)保留空格。
在用逗号(,
)分隔的列表(Less 函数参数列表、以 , 分隔的属性值等)中,逗号后必须(MUST)保留一个空格,逗号前不得(MUST NOT)保留空格。
正例:
.box { |
反例:
.box{ |
运算
+
/ -
/ *
/ / 四个运算符两侧必须(MUST)保留一个空格。+
/ -
两侧的操作数必须(MUST)有相同的单位,如果其中一个是变量,另一个数值必须(MUST)书写单位。
正例:
@a:200px; |
反例:
@a:200px; |
混入(Mixin)
Mixin 和后面的空格之间不得(MUST NOT)包含空格。在给 mixin 传递参数时,在参数分隔符(, / ;)后必须(MUST)保留一个空格:
正例:
.box { |
反例:
.box { |
选择器
当多个选择器共享一个声明块时,每个选择器声明必须(MUST)独占一行。
正例:
h1, |
反例:
h1, h2, h3 { |
Class 命名不得以样式信息进行描述,如 .float-right、text-red 等。
省略与缩写
缩写
多个属性定义可以使用缩写时, 尽量(SHOULD)使用缩写。缩写更清晰字节数更少。常见缩写有 margin
、border
、padding
、font
、list-style
等。在书写时必须(MUST)考量缩写展开后是否有不需要覆盖的属性内容被修改,从而带来副作用。
数值
对于处于 (0, 1)
范围内的数值,小数点前的 0
可以(MAY)省略,同一项目中必须(MUST)保持一致。
正例:
transition-duration:.5s,.7s; |
反例:
transition-duration:0.5s,.7s; |
0 值
当属性值为 0 时,必须(MUST)省略可省的单位(长度单位如 px
、em
,不包括时间、角度等如 s
、deg
)。
正例:
margin-top:0; |
反例:
margin-top:0px; |
颜色
颜色定义必须(MUST)使用 #rrggbb
格式定义,并在可能时尽量(SHOULD)缩写为 #rgb
形式,且避免直接使用颜色名称与 rgb()
表达式。
正例:
border-color:#f00; |
反例:
border-color: red; |
私有属性前缀
同一属性有不同私有前缀的,尽量(SHOULD)按前缀长度降序书写,标准形式必须(MUST)写在最后。且这一组属性以第一条的位置为准,尽量(SHOULD)按冒号的位置对齐。
正例:
.box { |
其他
可以(MAY)在无其他更好解决办法时使用 CSS hack,并且尽量(SHOULD)使用简单的属性名 hack 如 _zoom
、*margin
。
可以(MAY)但谨慎使用 IE 滤镜。需要注意的是,IE 滤镜中图片的 URL 是以页面路径作为相对目录,而不是 CSS 文件路径。
嵌套和缩进
必须(MUST)采用 4 个空格为一次缩进, 不得(MUST NOT)采用 TAB 作为缩进。
嵌套的声明块前必须(MUST)增加一次缩进,有多个声明块共享命名空间时尽量(SHOULD)嵌套书写,避免选择器的重复。
但是需注意的是,尽量(SHOULD)仅在必须区分上下文时才引入嵌套关系(在嵌套书写前先考虑如果不能嵌套,会如何书写选择器)。
正例:
.main { |
反例:
.main .title { |
变量
Less 的变量值总是以同一作用域下最后一个同名变量为准,务必注意后面的设定会覆盖所有之前的设定。
变量命名必须(MUST)采用 @foo-bar 形式,不得(MUST NOT)使用 @fooBar 形式。
正例:
@sidebar-width:200px; |
反例:
@sidebarWidth:200px; |
继承
使用继承时,如果在声明块内书写 :extend 语句,必须(MUST)写在开头:
正例:
.sub{ |
反例:
.sub{ |
混入(Mixin)
在定义 mixin 时,如果 mixin 名称不是一个需要使用的 className,必须(MUST)加上括号,否则即使不被调用也会输出到 CSS 中。
正例:
.big-text(){ |
反例:
.big-text { |
如果混入的是本身不输出内容的 mixin,必须(MUST)在 mixin 后添加括号(即使不传参数),以区分这是否是一个 className(修改以后是否会影响 HTML)。
正例:
.box { |
反例:
.box { |
Mixin 的参数分隔符使用 , 和 ; 均可,但在同一项目中必须(MUST)保持统一。
命名空间
变量和 mixin 在命名时必须(MUST)遵循如下原则:
- 一个项目只能引入一个无命名前缀的基础样式库(如 est)
- 业务代码和其他被引入的样式代码中,变量和 mixin 必须有项目或库的前缀
字符串
在进行字符串转义时,使用 ~""
表达式与 e()
函数均可,但在同一项目中必须(MUST)保持一致。
字符串两侧的引号必须(MUST)使用 "
。
JS 表达式
可以(MAY)使用 JS 表达式(~``
)生成属性值或变量,其中包含的字符串两侧的引号尽量(SHOULD)使用单引号('
)。
注释
单行注释尽量(SHOULD)使用 //
方式。
// Hide everything |