// 引入vue模版的eslint import pluginVue from 'eslint-plugin-vue' import eslint from '@eslint/js' // ts-eslint解析器,使 eslint 可以解析 ts 语法 import tseslint from 'typescript-eslint' // vue文件解析器 import vueParser from 'vue-eslint-parser' import prettier from 'eslint-plugin-prettier' export default tseslint.config({ // ignores: ['node_modules', 'prettier.config.cjs', 'dist*'], files: ['src/**/*.ts', 'src/**/*.tsx', 'src/**/*.vue'], // tseslint.config添加了extends扁平函数,直接用。否则是eslint9.0版本是没有extends的 extends: [eslint.configs.recommended, ...tseslint.configs.recommended, ...pluginVue.configs['flat/essential']], plugins: { prettier }, languageOptions: { parser: vueParser, // 使用vue解析器,这个可以识别vue文件 parserOptions: { parser: tseslint.parser, // 在vue文件上使用ts解析器 sourceType: 'module', ecmaVersion: 2020, jsxPragma: 'React', ecmaFeatures: { jsx: true } } }, rules: { // eslint (http://eslint.cn/docs/rules) 'no-useless-escape': 0, // 关闭不必要的转义 'no-var': 'error', // 要求使用 let 或 const 而不是 var 'no-multiple-empty-lines': ['error', { max: 1 }], // 不允许多个空行 'prefer-const': 1, // 使用 let 关键字声明但在初始分配后从未重新分配的变量,要求使用 const 'no-use-before-define': 0, // 禁止在 函数/类/变量 定义之前使用它们 'prettier/prettier': [ 'warn', { singleQuote: true, semi: false } ], // typeScript (https://typescript-eslint.io/rules) '@typescript-eslint/no-unused-vars': 0, // 禁止定义未使用的变量 '@typescript-eslint/no-empty-function': 0, // 禁止空函数 'no-empty': 0, // 判据可以为空 '@typescript-eslint/prefer-ts-expect-error': 'error', // 禁止使用 @ts-ignore '@typescript-eslint/ban-ts-comment': 'error', // 禁止 @ts- 使用注释或要求在指令后进行描述 '@typescript-eslint/no-inferrable-types': 0, // 可以轻松推断的显式类型可能会增加不必要的冗长 '@typescript-eslint/no-namespace': 0, // 禁止使用自定义 TypeScript 模块和命名空间 '@typescript-eslint/no-explicit-any': 0, // 禁止使用 any 类型 '@typescript-eslint/ban-types': 0, // 禁止使用特定类型 '@typescript-eslint/no-var-requires': 0, // 允许使用 require() 函数导入模块 '@typescript-eslint/no-non-null-assertion': 0, // 不允许使用后缀运算符的非空断言(!) '@typescript-eslint/no-unused-expressions': 0, // 方法可以不返回 // vue (https://eslint.vuejs.org/rules) // 'vue/script-setup-uses-vars': 'error', // 防止