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", }, };