-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.cjs
78 lines (73 loc) · 2.35 KB
/
.eslintrc.cjs
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
module.exports = {
root: true,
env: { browser: true, node: true, es2020: true },
/* 继承某些已有的规则 */
extends: [
'eslint:recommended',
'plugin:@typescript-eslint/recommended',
'plugin:react-hooks/recommended',
'plugin:prettier/recommended', // 添加 prettier 插件
],
/* 指定如何解析语法 */
parser: '@typescript-eslint/parser',
/* 优先级低于 parse 的语法解析配置 */
parserOptions: {
ecmaVersion: 'latest',
sourceType: 'module',
jsxPragma: 'React',
ecmaFeatures: {
jsx: true,
},
},
/* 插件 */
plugins: ['react', '@typescript-eslint', 'react-hooks', 'react-refresh', 'simple-import-sort'],
/**
* 自定义规则
* "off" 或 0 ==> 关闭规则
* "warn" 或 1 ==> 打开的规则作为警告(不影响代码执行)
* "error" 或 2 ==> 规则作为一个错误(代码不能执行,界面报错)
*/
rules: {
'react-refresh/only-export-components': 'warn',
'@typescript-eslint/no-explicit-any': 'off', // 禁止使用 any 类型
'@typescript-eslint/ban-types': 'off', // 禁止使用特定类型
'@typescript-eslint/no-non-null-assertion': 'off', // 不允许使用后缀运算符的非空断言(!)
'react-hooks/rules-of-hooks': 'off',
'react-hooks/exhaustive-deps': 'off',
'simple-import-sort/imports': [
'error',
{
groups: [
[
// 以字母(或数字或下划线)或“@”后面跟着字母开头的东西,通常为内置模块引入
'^@?\\w',
// 内部导入 "@/"
'^@(/.*|$)',
`^@/assets$`,
`^@/components$`,
`^@/config$`,
`^@/hooks$`,
`^@/plugins$`,
`^@/routers$`,
`^@/store$`,
`^@/styles$`,
`^@/utils$`,
// 父级导入. 把 `..` 放在最后.
'^\\.\\.(?!/?$)',
'^\\.\\./?$',
// 同级导入. 把同一个文件夹.放在最后
'^\\./(?=.*/)(?!/?$)',
'^\\.(?!/?$)',
'^\\./?$',
// 样式导入.
'^.+\\.?(css|less|scss)$',
// 带有副作用导入,比如import 'a.css'这种.
'^\\u0000',
],
],
},
],
'simple-import-sort/exports': 'error', // 导出
'import/order': 'off',
},
};