主题
eslint.config.js
js
import js from '@eslint/js';
import tsPlugin from '@typescript-eslint/eslint-plugin';
import tsParser from '@typescript-eslint/parser';
import prettierConfig from 'eslint-config-prettier';
import pluginVue from 'eslint-plugin-vue';
import { defineConfig, globalIgnores } from 'eslint/config';
import * as parserVue from 'vue-eslint-parser';
export default defineConfig([
globalIgnores([
'**/.*',
'dist/*',
'**/*.d.ts',
'public/*',
'src/assets/**',
'node_modules/**',
'src/components/VueBits/**',
]),
{
...js.configs.recommended,
ignores: ['src/assets/**'],
languageOptions: {
globals: {},
},
rules: {
...prettierConfig.rules,
},
},
{
files: ['**/*.d.ts'],
rules: {
'eslint-comments/no-unlimited-disable': 'off',
'import/no-duplicates': 'off',
'no-restricted-syntax': 'off',
'unused-imports/no-unused-vars': 'off',
prettier: 'off',
},
},
{
files: ['**/*.vue'],
languageOptions: {
globals: {},
parser: parserVue,
parserOptions: {
ecmaFeatures: {
jsx: true,
},
extraFileExtensions: ['.vue'],
sourceType: 'module',
// 使用 TypeScript 解析器解析 <script lang="ts">
parser: tsParser,
},
},
plugins: {
vue: pluginVue,
},
processor: pluginVue.processors['.vue'],
rules: {
...pluginVue.configs.base.rules,
...pluginVue.configs.essential.rules,
...pluginVue.configs.recommended.rules,
// 要求组件名称总是多个单词
'vue/multi-word-component-names': 0,
// 自闭标志
'vue/html-self-closing': [
'error',
{
html: {
void: 'always',
normal: 'always',
component: 'always',
},
svg: 'always',
math: 'always',
},
],
'vue/valid-template-root': 'off',
},
},
{
files: ['**/*.ts'],
languageOptions: {
parser: tsParser,
parserOptions: {
ecmaVersion: 'latest',
sourceType: 'module',
project: './tsconfig.json',
},
},
plugins: {
'@typescript-eslint': tsPlugin,
},
rules: {
...tsPlugin.configs.recommended.rules,
// TypeScript 特定规则
'@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_' }],
'@typescript-eslint/no-explicit-any': 'warn',
'@typescript-eslint/explicit-function-return-type': 'off',
'@typescript-eslint/explicit-module-boundary-types': 'off',
'@typescript-eslint/no-inferrable-types': 'off',
'@typescript-eslint/no-var-requires': 'error',
'no-var': 'error',
// 与 Prettier 兼容
...prettierConfig.rules,
},
},
]);
