|
| 1 | +// @see: http://eslint.cn |
| 2 | + |
| 3 | +module.exports = { |
| 4 | + root: true, |
| 5 | + env: { |
| 6 | + browser: true, |
| 7 | + node: true, |
| 8 | + es6: true |
| 9 | + }, |
| 10 | + // 指定如何解析语法 |
| 11 | + parser: "vue-eslint-parser", |
| 12 | + // 优先级低于 parse 的语法解析配置 |
| 13 | + parserOptions: { |
| 14 | + parser: "@typescript-eslint/parser", |
| 15 | + ecmaVersion: 2020, |
| 16 | + sourceType: "module", |
| 17 | + jsxPragma: "React", |
| 18 | + ecmaFeatures: { |
| 19 | + jsx: true |
| 20 | + } |
| 21 | + }, |
| 22 | + // 继承某些已有的规则 |
| 23 | + extends: ["plugin:vue/vue3-recommended", "plugin:@typescript-eslint/recommended", "plugin:prettier/recommended"], |
| 24 | + /** |
| 25 | + * "off" 或 0 ==> 关闭规则 |
| 26 | + * "warn" 或 1 ==> 打开的规则作为警告(不影响代码执行) |
| 27 | + * "error" 或 2 ==> 规则作为一个错误(代码不能执行,界面报错) |
| 28 | + */ |
| 29 | + rules: { |
| 30 | + // eslint (http://eslint.cn/docs/rules) |
| 31 | + "no-var": "error", // 要求使用 let 或 const 而不是 var |
| 32 | + "no-multiple-empty-lines": ["error", { max: 1 }], // 不允许多个空行 |
| 33 | + "prefer-const": "off", // 使用 let 关键字声明但在初始分配后从未重新分配的变量,要求使用 const |
| 34 | + "no-use-before-define": "off", // 禁止在 函数/类/变量 定义之前使用它们 |
| 35 | + "no-irregular-whitespace": "off", // 禁止不规则的空白 |
| 36 | + |
| 37 | + // typeScript (https://typescript-eslint.io/rules) |
| 38 | + "@typescript-eslint/no-unused-vars": "error", // 禁止定义未使用的变量 |
| 39 | + "@typescript-eslint/prefer-ts-expect-error": "error", // 禁止使用 @ts-ignore |
| 40 | + "@typescript-eslint/no-inferrable-types": "off", // 可以轻松推断的显式类型可能会增加不必要的冗长 |
| 41 | + "@typescript-eslint/no-namespace": "off", // 禁止使用自定义 TypeScript 模块和命名空间。 |
| 42 | + "@typescript-eslint/no-explicit-any": "off", // 禁止使用 any 类型 |
| 43 | + "@typescript-eslint/ban-types": "off", // 禁止使用特定类型 |
| 44 | + "@typescript-eslint/explicit-function-return-type": "off", // 不允许对初始化为数字、字符串或布尔值的变量或参数进行显式类型声明 |
| 45 | + "@typescript-eslint/no-var-requires": "off", // 不允许在 import 语句中使用 require 语句 |
| 46 | + "@typescript-eslint/no-empty-function": "off", // 禁止空函数 |
| 47 | + "@typescript-eslint/no-use-before-define": "off", // 禁止在变量定义之前使用它们 |
| 48 | + "@typescript-eslint/ban-ts-comment": "off", // 禁止 @ts-<directive> 使用注释或要求在指令后进行描述 |
| 49 | + "@typescript-eslint/no-non-null-assertion": "off", // 不允许使用后缀运算符的非空断言(!) |
| 50 | + "@typescript-eslint/explicit-module-boundary-types": "off", // 要求导出函数和类的公共类方法的显式返回和参数类型 |
| 51 | + |
| 52 | + // vue (https://eslint.vuejs.org/rules) |
| 53 | + "vue/script-setup-uses-vars": "error", // 防止<script setup>使用的变量<template>被标记为未使用,此规则仅在启用该no-unused-vars规则时有效。 |
| 54 | + "vue/v-slot-style": "error", // 强制执行 v-slot 指令样式 |
| 55 | + "vue/no-mutating-props": "off", // 不允许组件 prop的改变 |
| 56 | + "vue/no-v-html": "off", // 禁止使用 v-html |
| 57 | + "vue/custom-event-name-casing": "off", // 为自定义事件名称强制使用特定大小写 |
| 58 | + "vue/attributes-order": "off", // vue api使用顺序,强制执行属性顺序 |
| 59 | + "vue/one-component-per-file": "off", // 强制每个组件都应该在自己的文件中 |
| 60 | + "vue/html-closing-bracket-newline": "off", // 在标签的右括号之前要求或禁止换行 |
| 61 | + "vue/max-attributes-per-line": "off", // 强制每行的最大属性数 |
| 62 | + "vue/multiline-html-element-content-newline": "off", // 在多行元素的内容之前和之后需要换行符 |
| 63 | + "vue/singleline-html-element-content-newline": "off", // 在单行元素的内容之前和之后需要换行符 |
| 64 | + "vue/attribute-hyphenation": "off", // 对模板中的自定义组件强制执行属性命名样式 |
| 65 | + "vue/require-default-prop": "off", // 此规则要求为每个 prop 为必填时,必须提供默认值 |
| 66 | + "vue/multi-word-component-names": "off" // 要求组件名称始终为 “-” 链接的单词 |
| 67 | + } |
| 68 | +}; |
0 commit comments