.eslintrc.cjs 3.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. // @see: http://eslint.cn
  2. module.exports = {
  3. root: true,
  4. env: {
  5. browser: true,
  6. node: true,
  7. es6: true
  8. },
  9. plugins: ['vue', '@typescript-eslint', 'import', 'promise', 'node', 'prettier'],
  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: [
  24. 'plugin:vue/vue3-recommended',
  25. 'plugin:@typescript-eslint/recommended',
  26. 'plugin:prettier/recommended',
  27. './.eslintrc-auto-import.json',
  28. 'prettier'
  29. ],
  30. /**
  31. * "off" 或 0 ==> 关闭规则
  32. * "warn" 或 1 ==> 打开的规则作为警告(不影响代码执行)
  33. * "error" 或 2 ==> 规则作为一个错误(代码不能执行,界面报错)
  34. */
  35. rules: {
  36. // eslint (http://eslint.cn/docs/rules)
  37. 'no-var': 'error', // 要求使用 let 或 const 而不是 var
  38. 'no-multiple-empty-lines': ['error', { max: 1 }], // 不允许多个空行
  39. 'prefer-const': 'off', // 使用 let 关键字声明但在初始分配后从未重新分配的变量,要求使用 const
  40. 'no-use-before-define': 'off', // 禁止在 函数/类/变量 定义之前使用它们
  41. 'prettier/prettier': [
  42. 'warn',
  43. {
  44. singleQuote: true,
  45. semi: false
  46. }
  47. ],
  48. // typeScript (https://typescript-eslint.io/rules)
  49. '@typescript-eslint/no-unused-vars': 'error', // 禁止定义未使用的变量
  50. '@typescript-eslint/no-empty-function': 'error', // 禁止空函数
  51. '@typescript-eslint/prefer-ts-expect-error': 'error', // 禁止使用 @ts-ignore
  52. '@typescript-eslint/ban-ts-comment': 'error', // 禁止 @ts-<directive> 使用注释或要求在指令后进行描述
  53. '@typescript-eslint/no-inferrable-types': 'off', // 可以轻松推断的显式类型可能会增加不必要的冗长
  54. '@typescript-eslint/no-namespace': 'off', // 禁止使用自定义 TypeScript 模块和命名空间
  55. '@typescript-eslint/no-explicit-any': 'off', // 禁止使用 any 类型
  56. '@typescript-eslint/ban-types': 'off', // 禁止使用特定类型
  57. '@typescript-eslint/no-var-requires': 'off', // 允许使用 require() 函数导入模块
  58. '@typescript-eslint/no-non-null-assertion': 'off', // 不允许使用后缀运算符的非空断言(!)
  59. // vue (https://eslint.vuejs.org/rules)
  60. 'vue/script-setup-uses-vars': 'error', // 防止<script setup>使用的变量<template>被标记为未使用,此规则仅在启用该 no-unused-vars 规则时有效
  61. 'vue/v-slot-style': 'error', // 强制执行 v-slot 指令样式
  62. 'vue/no-mutating-props': 'error', // 不允许改变组件 prop
  63. 'vue/custom-event-name-casing': 'error', // 为自定义事件名称强制使用特定大小写
  64. 'vue/html-closing-bracket-newline': 'error', // 在标签的右括号之前要求或禁止换行
  65. 'vue/attribute-hyphenation': 'error', // 对模板中的自定义组件强制执行属性命名样式:my-prop="prop"
  66. 'vue/attributes-order': 'off', // vue api使用顺序,强制执行属性顺序
  67. 'vue/no-v-html': 'off', // 禁止使用 v-html
  68. 'vue/require-default-prop': 'off', // 此规则要求为每个 prop 为必填时,必须提供默认值
  69. 'vue/multi-word-component-names': 'off', // 要求组件名称始终为 “-” 链接的单词
  70. 'vue/no-setup-props-destructure': 'off' // 禁止解构 props 传递给 setup
  71. }
  72. }