module.exports = { root: true, env: { browser: true, node: true, es6: true }, parser: 'vue-eslint-parser', parserOptions: { parser: '@typescript-eslint/parser', ecmaVersion: 'latest', sourceType: 'module', jsxPragma: 'React', ecmaFeatures: { jsx: true } }, extends: [ 'plugin:vue/vue3-recommended', 'plugin:@typescript-eslint/recommended', 'prettier', 'plugin:prettier/recommended' // 一定要放在最后。因为 extends 中后引入的规则会覆盖前面的规则。 ], rules: { // @typescript-eslint '@typescript-eslint/explicit-function-return-type': 'off', // 需要函数和类方法的显式返回类型 '@typescript-eslint/no-explicit-any': 'off', // 禁止使用该 any 类型 '@typescript-eslint/no-var-requires': 'off', // 不允许使用 require 语句,除了在 import 语句中 '@typescript-eslint/no-empty-function': 'off', // 禁止空函数 '@typescript-eslint/no-use-before-define': 'off', // 在定义之前禁止使用变量 '@typescript-eslint/ban-ts-comment': 'off', // 禁止 @ts- 使用评论或在指令后要求描述 '@typescript-eslint/ban-types': 'off', // 禁止使用特定类型 '@typescript-eslint/no-non-null-assertion': 'off', // '!'不允许使用后缀运算符的非空断言 '@typescript-eslint/explicit-module-boundary-types': 'off', // 需要导出函数和类的公共类方法的显式返回和参数类型 '@typescript-eslint/no-unused-vars': [ 'error', { argsIgnorePattern: '^_', varsIgnorePattern: '^_' } ], // 禁止未使用的变量 // vue 'vue/custom-event-name-casing': 'off', // 为自定义事件名称强制使用特定大小写 'vue/attributes-order': 'off', // 强制执行属性顺序 'vue/one-component-per-file': 'off', // 强制每个组件都应该在自己的文件中 'vue/html-closing-bracket-newline': 'off', // 在标签的右括号之前要求或禁止换行 'vue/multiline-html-element-content-newline': 'off', // 在多行元素的内容之前和之后需要换行符 'vue/singleline-html-element-content-newline': 'off', // 在单行元素的内容之前和之后需要换行符 'vue/attribute-hyphenation': 'off', // 对模板中的自定义组件强制执行属性命名样式 'vue/require-default-prop': 'off', // 需要 props 的默认值 'vue/html-indent': ['error', 2], // 在