-
Notifications
You must be signed in to change notification settings - Fork 30
/
stylelint.config.js
136 lines (121 loc) · 4.36 KB
/
stylelint.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
/**
* Stylelint Config for `QMUI Web Demo`
*
* https://stylelint.io/
*/
module.exports = {
'ignoreFiles': ['public/**/*.css'],
'plugins': [
'stylelint-wechat-work-css'
],
'rules': {
/**
* Plungins
*/
// @include 黑名单
'wechat-work/unused-mixins':
[
'display-flex',
'flexbox',
'/^flex-/',
'/^transition/',
'/^transform/',
'/^translate/',
'/^scale/',
'/^rotate/',
'/^animation/',
'box-sizing',
'box_sizing',
'inlineBlock',
'box-shadow',
'box_shadow',
'opacity',
'keyframes'
],
'wechat-work/comments-in-header': true, // 文件头部需要有注释 @date 和 @author
'wechat-work/selector-namespace-follow-filename': [true, {
'fileDirWhiteList': ['widget'],
'filenameWhitelist': []
}], // 业务CSS 的命名空间需要跟随文件名(关于命名空间请浏览器:http://qmuiteam.com/web/page/codeNorm.html#qui_htmlAndCSSNorm)
'wechat-work/unused-nested-selector-namespace': true, // 不建议在嵌套中使用 qui_ 开头的类
/**
* Color
*/
'color-hex-length': 'short', // 指定十六进制颜色是否使用缩写
// 禁止使用颜色名称
'color-named': ['never', {
'ignore': ['inside-function']
}],
/**
* Function
*/
'function-comma-space-after': 'always', // 函数内的内容,逗号之后要求有一个空格或禁止有空白
/**
* Number
*/
'number-leading-zero': 'never', // 禁止书写小数的前导 0
'number-no-trailing-zeros': true, // 禁止数字中的拖尾 0
/**
* String
*/
'string-quotes': 'double', // 字符串用双引号
/**
* Length
*/
'length-zero-no-unit': true, // 长度值为0时,禁止带单位
/**
* Block
*/
'block-opening-brace-space-before': 'always', // 尖括号前必须有空格
/**
* Selector
*/
'selector-max-id': 0, // 选择器不能为 id
'selector-combinator-space-after': 'always', // 在关系选择符之后要求有一个空格或禁止有空白
'selector-max-compound-selectors': 4, // 限制复合选择器的数量
// 选择器命名规范
'selector-class-pattern': ['^((?!js)[a-z][a-zA-Z0-9]*)(_[a-zA-Z0-9]+)*$', {
'resolveNestedSelectors': true
}],
/**
* Declaration
*/
'declaration-colon-space-after': 'always', // 在冒号之后要求有一个空格或禁止有空白
'declaration-block-semicolon-newline-after': 'always', // 在声明块的分号之后要求有一个换行符或禁止有空白
// 不能用的规则,目前有 border: none; 建议为 border: 0;或 border: 0 none;
'declaration-property-value-blacklist': {
'border': ['none']
},
/**
* Property
*/
'property-no-vendor-prefix': true, // 禁止使用带浏览器前缀的属性
/**
* Value
*/
'value-no-vendor-prefix': true, // 禁止使用带浏览器前缀的属性值
'value-list-comma-space-after': 'always', // 在属性值的内容中,逗号之后要求有一个空格或禁止有空白
/**
* At-rule
*/
'at-rule-no-vendor-prefix': true, // 禁止 at(@) 规则使用浏览器前缀
'keyframe-declaration-no-important': true, // 禁止在 keyframe 声明中使用 !important
/**
* Rule
*/
// 除特殊情况,规则前必须有空行
'rule-empty-line-before': ['always', {
'ignore': ['after-comment', 'inside-block']
}],
/**
* Comment
*/
'comment-no-empty': true, // 禁止空注释,CSS 规则内注释不受限制
'comment-whitespace-inside': 'always', // 注释前后需要有空格
/**
* General / Sheet
*/
'max-nesting-depth': 4, // 限制允许嵌套的深度
'indentation': 4 // 缩进,4 spaces
}
}