-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eslintrc.cjs
159 lines (157 loc) · 8.48 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
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
module.exports = {
env: { browser: true, node: true },
// parserOptions: { ecmaFeatures: { jsx: true }, ecmaVersion: 2018, sourceType: 'module' },
// plugins: ['react', 'react-hooks'],
globals: {
Atomics: 'readonly',
SharedArrayBuffer: 'readonly',
_: true,
$: true
},
extends: [
'airbnb',
'airbnb-typescript',
'airbnb/hooks',
'plugin:react/recommended',
'plugin:@typescript-eslint/recommended',
'plugin:tailwindcss/recommended'
],
overrides: [],
parser: '@typescript-eslint/parser',
parserOptions: {
ecmaVersion: 'latest',
sourceType: 'module',
project: './tsconfig.json'
},
plugins: ['react', 'react-hooks', '@typescript-eslint', 'tailwindcss'],
rules: {
strict: 'off',
eqeqeq: 2, // 使用全等 === 不能使用==
'tailwindcss/classnames-order': 'warn',
'tailwindcss/no-custom-classname': 'warn',
'tailwindcss/no-contradicting-classname': 'error',
'tailwindcss/enforces-shorthand': 'warn',
'no-console': process.env.NODE_ENV === 'production' ? 'warn' : 'off', // console在生产模式不生效
'no-debugger': process.env.NODE_ENV === 'production' ? 'warn' : 'off', // debugger在生产模式不生效
'import/no-dynamic-require': 'off',
'import/no-unresolved': 0,
'import/prefer-default-export': 0,
'import/no-extraneous-dependencies': 0,
'implicit-arrow-linebreak': 0,
'import/extensions': 0,
'no-useless-escape': 0,
'global-require': 'off',
'require-yield': 'off',
'no-plusplus': 0,
'no-case-declarations': 'error',
'array-callback-return': 0,
'default-param-last': 0,
'consistent-return': 0,
'no-param-reassign': 0,
quotes: [2, 'single'], // 单引号
semi: 0, // 不强制使用分号
'max-len': 0,
'no-control-regex': 2, // 禁止在正则表达式中使用控制字符 :new RegExp("\x1f")
'linebreak-style': 0, // 强制使用一致的换行风格
indent: ['error', 2, { SwitchCase: 1 }], // 空格2个
'array-bracket-spacing': [2, 'never'], // 指定数组的元素之间要以空格隔开(,后面)
'brace-style': [2, '1tbs', { allowSingleLine: true }], // if while function 后面的{必须与if在同一行,java风格。
'no-irregular-whitespace': 0, // 不规则的空白不允许
'no-trailing-spaces': 1, // 一行结束后面有空格就发出警告
'eol-last': 0, // 文件以单一的换行符结束
'no-unused-vars': [1, { vars: 'all', args: 'after-used' }], // 不能有声明后未被使用的变量或参数
'no-underscore-dangle': 0, // 标识符不能以_开头或结尾
'no-alert': 2, // 禁止使用alert confirm prompt
'no-lone-blocks': 0, // 禁止不必要的嵌套块
'no-class-assign': 2, // 禁止给类赋值
'no-floating-decimal': 2, // 禁止数字字面量中使用前导和末尾小数点
'no-loop-func': 1, // 禁止在循环中出现 function 声明和表达式
'no-cond-assign': 2, // 禁止在条件表达式中使用赋值语句
'no-delete-var': 2, // 不能对var声明的变量使用delete操作符
'no-dupe-keys': 2, // 在创建对象字面量时不允许键重复
'no-duplicate-case': 2, // switch中的case标签不能重复
'no-dupe-args': 2, // 函数参数不能重复
'no-empty': 2, // 块语句中的内容不能为空
'no-func-assign': 2, // 禁止重复的函数声明
'no-invalid-this': 0, // 禁止无效的this,只能用在构造器,类,对象字面量
'no-redeclare': 2, // 禁止重复声明变量
'no-spaced-func': 2, // 函数调用时 函数名与()之间不能有空格
'no-this-before-super': 0, // 在调用super()之前不能使用this或super
'no-undef': 1, // 不能有未定义的变量
'no-use-before-define': 2, // 未定义前不能使用
'comma-dangle': ['error', 'never'], // 取消结尾逗号
'@typescript-eslint/comma-dangle': ['error', 'never'], // 取消结尾逗号
camelcase: 0, // 强制驼峰法命名
'object-curly-newline': [
'error',
{
ImportDeclaration: { multiline: true, minProperties: 3 },
ExportDeclaration: { multiline: true, minProperties: 3 }
}
], // import export 超过三个属性换行
'react/display-name': 0, // 防止在React组件定义中丢失displayName
'react/forbid-prop-types': [2, { forbid: ['any'] }], // 禁止某些propTypes
'react/jsx-boolean-value': 2, // 在JSX中强制布尔属性符号
'react/jsx-closing-bracket-location': 1, // 在JSX中验证右括号位置
'react/jsx-curly-spacing': [2, { when: 'never', children: true }], // 在JSX属性和表达式中加强或禁止大括号内的空格。
'react/jsx-indent-props': [2, 2], // 验证JSX中的props缩进
'react/jsx-key': 2, // 在数组或迭代器中验证JSX具有key属性
'react/jsx-no-bind': 0, // JSX中不允许使用箭头函数和bind
'react/jsx-no-duplicate-props': 2, // 防止在JSX中重复的props
'react/jsx-no-literals': 0, // 防止使用未包装的JSX字符串
'react/jsx-no-undef': 1, // 在JSX中禁止未声明的变量
'react/jsx-pascal-case': 0, // 为用户定义的JSX组件强制使用PascalCase
'react/jsx-uses-react': 1, // 防止反应被错误地标记为未使用
'react/jsx-uses-vars': 2, // 防止在JSX中使用的变量被错误地标记为未使用
'react/no-danger': 0, // 防止使用危险的JSX属性
'react/no-did-mount-set-state': 0, // 防止在componentDidMount中使用setState
'react/no-did-update-set-state': 1, // 防止在componentDidUpdate中使用setState
'react/no-direct-mutation-state': 2, // 防止this.state的直接变异
'react/no-multi-comp': 1, // 防止每个文件有多个组件定义
'react/no-set-state': 0, // 防止使用setState
'react/no-unknown-property': 2, // 防止使用未知的DOM属性
'react/prefer-es6-class': 2, // 为React组件强制执行ES5或ES6类
'react/prop-types': 0, // 防止在React组件定义中丢失props验证
'react/react-in-jsx-scope': 0, // 使用JSX时防止丢失React
'react/self-closing-comp': 0, // 防止没有children的组件的额外结束标签
'react/sort-comp': 1, // 强制组件方法顺序
'no-extra-boolean-cast': 0, // 禁止不必要的bool转换
'react/no-array-index-key': 0, // 防止在数组中遍历中使用数组key做索引
'react/no-deprecated': 1, // 不使用弃用的方法
'react/jsx-equals-spacing': 2, // 在JSX属性中强制或禁止等号周围的空格
'react/jsx-wrap-multilines': 0, // 在JSX中多行强制用括号包裹()
'react/jsx-one-expression-per-line': 0,
'react/jsx-no-constructed-context-values': 0,
'react/destructuring-assignment': 0,
'react-hooks/rules-of-hooks': 'error', // 检查 Hook 的规则
'react-hooks/exhaustive-deps': 'warn', // 检查 effect 的依赖
'no-unreachable': 1, // 不能有无法执行的代码
'comma-spacing': [2, { before: false, after: true }], // 控制逗号前后的空格
'no-mixed-spaces-and-tabs': 0, // 禁止混用tab和空格
'prefer-arrow-callback': 0, // 比较喜欢箭头回调
'arrow-body-style': 2, // 要求箭头函数体使用大括号
'arrow-parens': 2, // 要求箭头函数的参数使用圆括号
'arrow-spacing': [2, { before: true, after: true }],
'constructor-super': 0, // 强制在子类构造函数中用super()调用父类构造函数,TypeScrip的编译器也会提示
'no-const-assign': 2, // 禁止修改 const 声明的变量
'no-dupe-class-members': 2, // 禁止类成员中出现重复的名称
'no-var': 0, // 要求使用 let 或 const 而不是 var
'object-shorthand': 0, // 要求或禁止对象字面量中方法和属性使用简写语法
'prefer-template': 0, // 要求使用模板字面量而非字符串连接
'@typescript-eslint/no-empty-interface': 0,
'react/jsx-props-no-spreading': 0,
'@typescript-eslint/no-shadow': 0,
'object-curly-newline': 0,
'no-unused-vars': 0,
'@typescript-eslint/no-unused-vars': 0, // 是否允许保留未使用的变量
'@typescript-eslint/no-explicit-any': 0, // 是否允许 any 声明
'arrow-body-style': 0, // 是否允许尖头函数中只有一行且带{}
'@typescript-eslint/naming-convention': 1, // 驼峰命名
'react/no-multi-comp': 0,
'react/require-default-props': 0, // 组件默认 props 是否使用 .defaultProps 来声明
'jsx-a11y/anchor-is-valid': 0,
'react/no-unknown-property': 0,
'react-hooks/exhaustive-deps': 0, // react hooks 是否允许带空数组
'@typescript-eslint/no-non-null-assertion': 0
}
};