module.exports = { root: true, env: { browser: true, es2021: true, node: true, }, parser: 'vue-eslint-parser', extends: [ // https://eslint.vuejs.org/user-guide/#usage 'plugin:vue/vue3-recommended', './.eslintrc-auto-import.json', 'prettier', 'plugin:@typescript-eslint/recommended', 'plugin:prettier/recommended', ], parserOptions: { ecmaVersion: 'latest', sourceType: 'module', parser: '@typescript-eslint/parser', project: './tsconfig.*?.json', createDefaultProgram: false, extraFileExtensions: ['.vue'], }, plugins: ['vue', '@typescript-eslint'], rules: { // 禁止使用 var,用 let 和 const 代替 'no-var': 'error', // 在 Vue 的 v-for 循环中要求使用 :key 'vue/require-v-for-key': 'error', // vue的for循环是否必须有key // 关闭 Vue 组件名必须多字的规则 'vue/multi-word-component-names': 'off', // 关闭 Vue 的 v-model 中的参数规则 'vue/no-v-model-argument': 'off', // Vue 的 setup() 函数必须使用的变量规则 'vue/script-setup-uses-vars': 'error', // 关闭 Vue 组件名的保留规则 'vue/no-reserved-component-names': 'off', // 关闭 Vue 事件名的命名规则 'vue/custom-event-name-casing': 'off', // 关闭 Vue 属性的顺序规则 'vue/attributes-order': 'off', // 关闭一个文件只能有一个组件规则 'vue/one-component-per-file': 'off', // 关闭 HTML 标签闭合换行规则 'vue/html-closing-bracket-newline': 'off', // 关闭 HTML 属性每行最大数量规则 'vue/max-attributes-per-line': 'off', // 关闭多行 HTML 元素内容的规则 'vue/multiline-html-element-content-newline': 'off', // 关闭单行 HTML 元素内容的规则 'vue/singleline-html-element-content-newline': 'off', // 关闭 HTML 属性连字符的规则 'vue/attribute-hyphenation': 'off', // 关闭要求 Vue 默认属性的规则 'vue/require-default-prop': 'off', // 关闭要求 Vue 显式触发事件的规则 'vue/require-explicit-emits': 'off', // HTML 标签自闭合规则 'vue/html-self-closing': [ 'error', { html: { void: 'always', // 自闭合标签必须自闭合 normal: 'never', // 普通标签不得自闭合 component: 'always', // 组件标签必须自闭合 }, svg: 'always', math: 'always', }, ], // 警告空方法检查 '@typescript-eslint/no-empty-function': 'warn', // 关闭 any 类型的警告 '@typescript-eslint/no-explicit-any': 'off', // 关闭使用 @ts-ignore 的警告 '@typescript-eslint/ban-ts-ignore': 'off', // 关闭使用 @ts-comment 的警告 '@typescript-eslint/ban-ts-comment': 'off', // 关闭一些特定类型的警告 '@typescript-eslint/ban-types': 'off', // 关闭函数返回类型的警告 '@typescript-eslint/explicit-function-return-type': 'off', // 关闭 any 类型的警告 '@typescript-eslint/no-explicit-any': 'off', // 关闭使用 require 的警告 '@typescript-eslint/no-var-requires': 'off', // 关闭使用尚未定义的变量的警告 '@typescript-eslint/no-use-before-define': 'off', // 关闭模块导出类型的警告 '@typescript-eslint/explicit-module-boundary-types': 'off', // 未使用的变量的警告 '@typescript-eslint/no-unused-vars': 'warn', // Prettier 配置 'prettier/prettier': [ 'error', { useTabs: false, // 不使用制表符 }, ], }, // eslint不能对html文件生效 overrides: [ { files: ['*.html'], processor: 'vue/.vue', }, ], // https://eslint.org/docs/latest/use/configure/language-options#specifying-globals globals: { OptionType: 'readonly', }, };