-
Notifications
You must be signed in to change notification settings - Fork 12
/
.eslintrc.js
203 lines (194 loc) · 10.5 KB
/
.eslintrc.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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
console.log(
'\x1B[0;37;44m INFO \x1B[0m',
'\x1B[0;;34m ' +
`读取了: ${__filename.slice(__dirname.length + 1)}` +
' \x1B[0m'
);
module.exports = {
root: true,
settings: {
'import/parsers': {
'@typescript-eslint/parser': ['.ts', '.tsx'],
},
'import/resolver': {
typescript: {
alwaysTryTypes: true, // always try to resolve types under `<root>@types` directory even it doesn't contain any source code, like `@types/unist`
project: './tsconfig.json',
},
},
},
env: {
browser: true,
node: true,
},
extends: [
// 'airbnb-base', // airbnb的eslint规范,它会对import和require进行排序,挺好的。如果不用它的话,需要在env添加node:true
'eslint:recommended',
'plugin:import/recommended',
'plugin:vue/vue3-essential', // plugin:vue/vue3-essential或plugin:vue/vue3-strongly-recommended或plugin:vue/vue3-recommended'
'@vue/eslint-config-typescript', // 启用这个规则后,vscode保存文件时格式化很慢
// '@vue/eslint-config-typescript/recommended', // 启用这个规则后,vscode保存文件时格式化很慢
'@vue/eslint-config-prettier',
],
parser: 'vue-eslint-parser',
parserOptions: {
parser: '@typescript-eslint/parser',
ecmaVersion: 'latest',
ecmaFeatures: {
jsx: true,
},
tsconfigRootDir: __dirname, // https://typescript-eslint.io/docs/linting/typed-linting
project: ['./tsconfig.json'], // https://typescript-eslint.io/docs/linting/typed-linting
},
plugins: ['import'],
// overrides: [],
// rules会覆盖extends里面的规则(https://eslint.org/docs/latest/user-guide/migrating-to-6.0.0#-overrides-in-an-extended-config-file-can-now-be-overridden-by-a-parent-config-file)
// rules里面的规则不会对overrides里面的文件生效
rules: {
/**
* 0 => off
* 1 => warn
* 2 => error
*/
'no-unused-vars': 0, // 禁止出现未使用过的变量
'no-shadow': 0, // 禁止变量声明与外层作用域的变量同名
'class-methods-use-this': 0, // 类方法如果不使用this的话会报错
'no-console': 0, // 此规则不允许调用console对象的方法。
'spaced-comment': ['error', 'always', { exceptions: ['-', '+'] }], // 该规则强制注释中 // 或 /* 后空格的一致性
'no-var': 2, // 要求let或const代替var
camelcase: [
'error',
{ properties: 'never' }, // properties默认always,即检查属性名;可以设置为never,即不检查属性名
], // 强制执行驼峰命名约定
'no-underscore-dangle': 2, // 此规则不允许在标识符中使用悬空下划线。
'no-param-reassign': 2, // 禁止对 function 的参数进行重新赋值
'no-nested-ternary': 2, // 禁止嵌套三元
'no-plusplus': 2, // 禁用一元操作符 ++ 和 --
'vars-on-top': 2, // 要求所有的 var 声明出现在它们所在的作用域顶部
'prefer-const': 2, // 要求使用 const 声明那些声明后不再被修改的变量
'prefer-template': 2, // 要求使用模板字符串代替字符串连接
'new-cap': 2, // 要求构造函数名称以大写字母开头
'no-restricted-syntax': [
// 禁用一些语法
'error',
// 'ForInStatement',
// 'ForOfStatement',
{
selector: 'ForInStatement',
/**
* 用 map() / every() / filter() / find() / findIndex() / reduce() / some() / ... 遍历数组,
* 和使用 Object.keys() / Object.values() / Object.entries() 迭代你的对象生成数组。
* 拥有返回值得纯函数比这个更容易解释
*/
message:
'for in会迭代遍历原型链(__proto__),建议使用map/every/filter等遍历数组,使用Object.{keys,values,entries}等遍历对象',
},
{
selector: 'ForOfStatement',
message:
'建议使用map/every/filter等遍历数组,使用Object.{keys,values,entries}等遍历对象',
},
], // https://github.com/BingKui/javascript-zh#%E8%BF%AD%E4%BB%A3%E5%99%A8%E5%92%8C%E5%8F%91%E7%94%9F%E5%99%A8
'no-iterator': 2, // 禁止使用__iterator__迭代器
'require-await': 2, // 禁止使用不带 await 表达式的 async 函数
'no-empty': 2, // 禁止空块语句
'guard-for-in': 2, // 要求for-in循环包含if语句
'global-require': 2, // 此规则要求所有调用require()都在模块的顶层,此规则在 ESLint v7.0.0中已弃用。请使用 中的相应规则eslint-plugin-node:https://github.com/mysticatea/eslint-plugin-node
'no-unused-expressions': [
2,
{
allowShortCircuit: true, // 允许短路
allowTernary: true, // 允许三元
},
], // 禁止未使用的表达式,即let a = true && console.log(1)允许,但是true && console.log(1)不行
'object-shorthand': ['error', 'always'], // (默认)希望尽可能使用速记。var foo = {x:x};替换为var foo = {x};
'no-useless-escape': 2, // 禁止不必要的转义字符
// eslint-plugin-import插件
// https://github.com/import-js/eslint-plugin-import/blob/main/docs/rules/order.md
'import/order': [
'error',
{
groups: [
'builtin', // 如:import fs from 'fs';
'external', // 如:import _ from 'lodash';
'internal', // 如:import foo from 'src/foo';
'parent', // 如:import foo from '../foo';
'sibling', // 如:import bar from './bar';
// ['sibling', 'parent'],
// ['parent', 'sibling'],
'index', // 如:import main from './';
'object', // 如:import log = console.log;
'type', // 如:import type { Foo } from 'foo';
],
pathGroups: [
{
pattern: '@/**',
group: 'internal',
},
],
'newlines-between': 'always', // 强制或禁止导入组之间的新行
// 根据导入路径以字母顺序排列每个组中的顺序
alphabetize: {
order: 'asc', // 使用asc按升序排序,使用desc按降序排序(默认值:ignore)。
caseInsensitive: true, // 使用true忽略大小写,而false考虑大小写(默认值:false)。
orderImportKind: 'asc', // 使用asc以升序对各种导入类型进行排序,例如以type或typeof为前缀的导入,具有相同的导入路径。使用desc按降序排序(默认值:忽略)
},
},
],
'import/newline-after-import': 2, // 强制在最后一个顶级导入语句或 require 调用之后有一个或多个空行
'import/no-extraneous-dependencies': 2, // 禁止导入未在package.json中声明的外部模块。
/**
* a.js
* export const version = '1.0.0';
* export const bar = { name: 'bar', version };
* export default bar;
* b.js
* import bar from './a';
* console.log(bar.version); // 检测到你使用的version有具名导出,import/no-named-as-default-member就会提示`import {version} from './a'`
*/
'import/no-named-as-default-member': 1, // https://github.com/import-js/eslint-plugin-import/blob/v2.26.0/docs/rules/no-named-as-default-member.md
/**
* import/named
* 在import { version } from 'vuex';的时候会验证vuex有没有具名导出version,
* 但是在vue3的时候,import { defineComponent } from 'vue';会报错defineComponent not found in 'vue'
* 因此vue3项目关闭该规则
*/
// 'import/named': 0,
// 'import/prefer-default-export': 0, // 当模块只有一个导出时,更喜欢使用默认导出而不是命名导出。
// 'import/extensions': 0, // 确保在导入路径中一致使用文件扩展名。在js/ts等文件里引其他文件都不能带后缀(比如.css和.jpg),因此关掉
// 'import/no-unresolved': 0, // 不能解析带别名的路径的模块,但实际上是不影响代码运行的。找不到解决办法,暂时关掉。
/**
* a.js
* export const bar = 'bar';
* export const foo = 'foo';
* export default foo;
* b.js
* import bar from './a'; // import/no-named-as-default规则会报错,因为import/no-named-as-default规则误以为你将具名导出的bar作为了默认导出来使用,但是实际上可能我就是想用默认导出的foo
* // import barr from './a'; // 改个名字import/no-named-as-default规则就不会报错了。
* // 不幸的是,React + Redux 是最常见的场景。但是,还有很多其他情况,HOC 会迫使开发人员关闭此规则。https://github.com/import-js/eslint-plugin-import/issues/544#issuecomment-245082471
*/
'import/no-named-as-default': 0, // https://github.com/import-js/eslint-plugin-import/blob/v2.26.0/docs/rules/no-named-as-default.md
// @typescript-eslint插件
'@typescript-eslint/no-unused-vars': 2,
'@typescript-eslint/restrict-template-expressions': [
'error',
{
allowBoolean: true,
allowNumber: true,
},
], // 强制模板文字表达式为string类型。即const a = {};console.log(`${a}`);会报错
'@typescript-eslint/no-floating-promises': 0, // 要求适当处理类似 Promise 的语句。即将await或者return Promise,或者对promise进行.then或者.catch
'@typescript-eslint/no-explicit-any': 0, // 不允许定义any类型。即let a: any;会报错
'@typescript-eslint/no-non-null-assertion': 0, // 禁止使用非空断言(后缀运算符!)。即const el = document.querySelector('.app');console.log(el!.tagName);会报错
'@typescript-eslint/ban-ts-comment': 0, // 禁止使用@ts-<directive>注释
'@typescript-eslint/no-unsafe-assignment': 0, // 不允许将具有类型的值分配any给变量和属性。即const a: any = {};const b = a;会报错
'@typescript-eslint/no-unsafe-argument': 0, // 不允许用any类型的值调用一个函数。即let a: any;Object.keys(a);会报错
'@typescript-eslint/no-unsafe-member-access': 0, // 不允许对类型为any的值进行成员访问。即const a: any = [];console.log(a[0]);会报错
'@typescript-eslint/no-unsafe-return': 0, // 不允许从一个函数中返回一个类型为any的值
'@typescript-eslint/no-unsafe-call': 0, // 不允许调用any类型的值
'@typescript-eslint/no-var-requires': 0, // 即不允许var foo = require('foo');。但是允许import foo = require('foo');
'@typescript-eslint/restrict-plus-operands': 0, // 要求加法的两个操作数是相同的类型并且是bigint, number, 或string。即const a = '1';console.log(a + 1);会报错
// vueeslint插件
'vue/multi-word-component-names': 0,
},
};