前几天根据腾讯Alloy Team团队的js规范,配置了一套eslintrc,完成度90%+。配置采用js方式引入。
注意:这里引用了3个eslint插件,不要忘记安装。
module.exports = {
env: { // 定义一组预定义的全局变量
browser: true,
jquery: true
},
'extends': [
'eslint:recommended'
],
plugins: [
'html',
'require-jsdoc-except',
'dollar-sign'
],
rules: {
/*
* 以下为代码风格相关规则
*/
/* 缩进相关规则 */
indent: [1, 4, { // 使用4个空格缩进 switch-case中case要缩进
SwitchCase: 1
}],
/* 分号相关规则 */
semi: [1, 'always'], // 语句末尾强制使用分号 忽略花括号的最后一个分号
'semi-spacing': [1, { // 强制分号后有空格,禁止分号前有空格
before: false,
after: true
}],
'semi-style': 1, // 分号应该出现在句尾
/* 逗号相关规则 */
'comma-dangle': [1, 'never'], // 数组和对象键值对最后一个逗号
'comma-spacing': [1, { // 逗号之前禁止使用空格,逗号之后需要使用空格
before: false,
after: true
}],
/* 空格相关规则 */
'key-spacing': [1, { // 对象键值对 冒号前不需要空格 冒号后需要空格
beforeColon: false,
afterColon: true
}],
'no-multi-spaces': 1, // 禁止出现多个空格
'no-trailing-spaces': 1, // 禁止行尾空格
'no-whitespace-before-property': 1, // 禁止属性前有空白
'space-before-blocks': [1, 'always'], // 要求语句块之前的空格
'space-before-function-paren': [1, 'never'], // 紧致函数圆括号之前禁止有空格
'space-in-parens': 1, // 禁止在圆括号内使用空格
'space-infix-ops': 1, // 要求操作符周围有空格
'space-unary-ops': [1, { // 单词类一元操作符之后需要空格 非单词类一元操作符之前之后不需要空格
words: true, // 单词类一元操作符new、delete、typeof、void...
nonwords: false // 非单词类一元操作符-、+、--、++、!、!!...
}],
'spaced-comment': [1, 'always', { // 强制在注释中 // 或 /* 使用一致的空格
line: {
exceptions: ['-', '+'],
markers: ['/']
},
block: {
exceptions: ['*'],
markers: ['global', 'globals', 'eslint', 'eslint-disable', '*package', '!'],
balanced: true
}
}],
'array-bracket-spacing': 1, // 禁止在数组 '[' 后 和 ']' 前使用空格
'block-spacing': [1, 'always'], // 强制在左花括号和同一行上的下一个 token 之间有一致的空格,强制右花括号和在同一行的前一个 token 之间有一致的空格,
'computed-property-spacing': [1, 'never'], // 禁止在计算属性中使用空格
'func-call-spacing': 1, // 禁止在函数标识符和其调用之间有空格
'keyword-spacing': [1, { // 强制在关键字前后使用一致的空格
before: false,
after: true,
overrides: {
'else': {
before: true
},
'while': {
before: true
},
'catch': {
before: true
},
'finally': {
before: true
}
}
}],
'object-curly-spacing': [1, 'never'], // 禁止在对象的'{'后和'}'前出现空格
'switch-colon-spacing': 1, // 强制在 switch 的冒号后有空格,禁止在 switch 的冒号前有空格
/* 空行相关规则 */
'eol-last': [1, 'always'], // 强制非空文件末尾保留一行空行
'lines-around-comment': [1, { // 强制注释前添加一行空行
beforeBlockComment: true,
beforeLineComment: true,
allowBlockStart: true,
allowObjectStart: true,
allowArrayStart: true,
allowClassStart: true
}],
'lines-between-class-members': 1, // 强制类成员之间有一行空行
'no-multiple-empty-lines': [1, { // 最多两个连续空行
max: 2
}],
'padding-line-between-statements': [1, { // 强制函数声明后添加空行
blankLine: 'always',
prev: 'var',
next: '*'
}, { // 强制"像块的语句"后添加空行 如{}, if (a) {}, while (a) {}
blankLine: 'always',
prev: 'block-like',
next: '*'
}],
/* 换行相关规则 */
'one-var-declaration-per-line': 1, // 强制每个变量初始化语句换行
'operator-linebreak': [1, 'after'], // 强制把换行符放在操作符后面
'comma-style': 1, // 强制把换行符放在逗号后
'brace-style': [1, '1tbs'], // 强制大括号使用one true brace style风格,即将大括号放在控制语句或声明语句同一行的位置
/* 注释相关规则 */
// 'multiline-comment-style': 1, // 禁止使用连续的行注释来表示块注释。另外,要求块注释的每行之前有一个 *
'require-jsdoc-except/require-jsdoc': [1, { // 要求采用jsdoc方式给函数等添加注释
require: {
FunctionDeclaration: true,
MethodDefinition: true,
ClassDeclaration: true,
ArrowFunctionExpression: true,
FunctionExpression: true
},
ignore: ['controller', 'link', 'success', 'error']
}],
/* 引号相关规则 */
quotes: [1, 'single'], // js中必须单引号
/* 变量命名相关规则 */
camelcase: [1, { // 标准变量采用驼峰式命名(对象属性除外)
properties: 'never'
}],
'new-cap': 1, // 要求构造函数首字母大写
'id-blacklist': [1, 'break', 'case', 'catch', 'continue', 'default', 'delete', 'do', 'else', 'finally', 'for', 'function', 'if', 'in', 'instanceof', 'new', 'return', 'switch', 'this', 'throw', 'try', 'typeof', 'var', 'void', 'while', 'with', 'abstract', 'boolean', 'byte', 'char', 'class', 'const', 'debugger', 'double', 'enum', 'export', 'extends', 'final', 'float', 'goto', 'implements', 'import', 'int', 'interface', 'long', 'native', 'package', 'private', 'protected', 'public', 'short', 'static', 'super', 'synchronized', 'throws', 'transient', 'volatile'], // 禁止使用关键字或保留字作为变量名
'dollar-sign/dollar-sign': [2, 'ignoreProperties'], // jquery对象必须以'$'开头命名
/* 变量声明相关规则 */
// 'vars-on-top': 1, // 要求将变量声明放在它们作用域的顶部
'one-var': [1, 'consecutive'], // 每个作用域允许出现一个变量声明,但对连续的变量声明要求合并为单个声明
/* 函数相关规则 */
'wrap-iife': [1, 'inside'], // 立即执行函数外必须包一层括号
'func-names': [1, 'never'], // 不要给inline function命名
/* 数组、对象相关规则 */
'quote-props': [1, 'as-needed', { // 对象字面量属性名称 当为关键字或数字时使用引号, 否则不使用引号
keywords: true,
unnecessary: true,
numbers: true
}],
'object-curly-newline': [1, { // 非空对象要求换行
ObjectExpression: {
minProperties: 1
}
}],
'object-property-newline': 1, // 对象不同属性放在不同行上
/* 括号相关规则 */
curly: [1, 'all'], // 控制语句中即使只有一行也要使用大括号
/* jshint相关规则 */
eqeqeq: 1, // 强制使用 === 和 !==
'no-use-before-define': [1, { // 禁止变量和类先使用后声明
functions: false,
classes: true,
variables: true
}],
'no-new': 1, // 不要在一句代码中单单使用构造函数,记得将其赋值给某个变量
'no-extra-parens': 1, // 禁止不必要的括号
'no-unused-vars': 0, // 不检查 定义未使用变量
'no-undef': 0, // 不可以使用未定义变量
'no-console': 0, // 不可以cosole
'no-extend-native': 0, // 禁止扩展原生类型
'no-debugger': 1, // 存在debugger时会提示
'no-loop-func': 1, // 禁止在循环中声明函数
'no-array-constructor': 1, // 禁用Array构造函数,
'no-new-object': 1, // 禁用Object构造函数
'no-new-func': 1, // 禁用Function构造函数
'no-new-wrappers': 1, // 禁止对 String,Number 和 Boolean 使用 new 操作符
/* 杂项相关规则 */
'linebreak-style': 0, // 换行符统一用'LF'
'consistent-this': [1, '_this', 'that', 'self'], // 对上下文this的引用只能使用'_this', 'that', 'self'其中一个来命名
'no-empty-function': 1 // 禁止出现空函数
}
};
有什么看不明白的可以评论我,或者查看eslint文档。