diff --git a/.eslintrc.cjs b/.eslintrc.cjs new file mode 100644 index 00000000..7cd3c26f --- /dev/null +++ b/.eslintrc.cjs @@ -0,0 +1,109 @@ +module.exports = { + root: true, + env: { + browser: true, + node: true, + }, + extends: [ + 'eslint-config-prettier', + 'eslint:recommended', + 'plugin:@typescript-eslint/recommended', + 'plugin:vue/vue3-recommended', + 'plugin:vue/vue3-essential', + 'plugin:prettier/recommended', + ], + parser: 'vue-eslint-parser', + parserOptions: { + ecmaVersion: 2020, + sourceType: 'module', + parser: '@typescript-eslint/parser', + ecmaFeatures: { + jsx: true, + tsx: true, + }, + }, + plugins: ['vue', 'react'], + globals: { + defineProps: 'readonly', + defineEmits: 'readonly', + defineExpose: 'readonly', + withDefaults: 'readonly', + }, + rules: { + '@typescript-eslint/no-explicit-any': 'error', + 'prettier/prettier': 'error', + 'no-unused-vars': 'off', + '@typescript-eslint/no-unused-vars': 'off', + '@typescript-eslint/ban-types': 'error', + '@typescript-eslint/explicit-module-boundary-types': 'off', + '@typescript-eslint/no-var-requires': 'off', + '@typescript-eslint/no-non-null-assertion': 'off', + '@typescript-eslint/no-non-null-asserted-optional-chain': 'off', + '@typescript-eslint/consistent-type-imports': [ + 'error', + { disallowTypeAnnotations: false }, + ], // 强制导入类型显示标注 `import type xxx from 'xxx'` + 'accessor-pairs': 2, // 强制同时存在 `get` 与 `set` + 'constructor-super': 0, // 强制子类构造函数中使用 `super` 调用父类的构造函数 + curly: [2, 'all'], // `if`、`else` 强制使用 `{}` 包裹 + 'default-case': 2, // `switch` 中强制含有 `default` + eqeqeq: [2, 'allow-null'], // 强制使用严格判断 `===` + 'no-alert': 0, // 禁止使用 `alert`、`confirm` + 'no-array-constructor': 2, // 禁止使用数组构造器 + 'no-bitwise': 0, // 禁止使用按位运算符 + 'no-caller': 1, // 禁止使用 `arguments.caller`、`arguments.callee` + 'no-catch-shadow': 2, // 禁止 `catch` 子句参数与外部作用域变量同名 + 'no-class-assign': 2, // 禁止给类赋值 + 'no-cond-assign': 2, // 禁止在条件表达式中使用赋值语句 + 'no-const-assign': 2, // 禁止修改 `const` 声明的变量 + 'no-constant-condition': 2, // 禁止在条件中使用常量表达式 `if(true)`、`if(1)` + 'no-dupe-keys': 2, // 在创建对象字面量时不允许 `key` 重复 + 'no-dupe-args': 2, // 函数参数不能重复 + 'no-duplicate-case': 2, // `switch` 中的 `case` 标签不能重复 + 'no-eval': 1, // 禁止使用 `eval` + 'no-ex-assign': 2, // 禁止给 `catch` 语句中的异常参数赋值 + 'no-extend-native': 2, // 禁止扩展 `native` 对象 + 'no-extra-bind': 2, // 禁止不必要的函数绑定 + 'no-extra-boolean-cast': 2, // 禁止不必要的 `bool` 转换 + 'no-extra-parens': 2, // 禁止非必要的括号 + 'no-extra-semi': 2, // 禁止多余的冒号 + 'no-fallthrough': 1, // 禁止 `switch` 穿透 + 'no-func-assign': 2, // 禁止重复的函数声明 + 'no-implicit-coercion': 1, // 禁止隐式转换 + 'no-implied-eval': 2, // 禁止使用隐式 `eval` + 'no-invalid-regexp': 2, // 禁止无效的正则表达式 + 'no-invalid-this': 2, // 禁止无效的 `this` + 'no-irregular-whitespace': 2, // 禁止含有不合法空格 + 'no-iterator': 2, // 禁止使用 `__iterator__ ` 属性 + 'no-label-var': 2, // `label` 名不能与 `var` 声明的变量名相同 + 'no-labels': 2, // 禁止标签声明 + 'no-lone-blocks': 2, // 禁止不必要的嵌套块 + 'no-multi-spaces': 1, // 禁止使用多余的空格 + 'no-multiple-empty-lines': [1, { max: 2 }], // 空行最多不能超过 `2` 行 + 'no-new-func': 1, // 禁止使用 `new Function` + 'no-new-object': 2, // 禁止使用 `new Object` + 'no-new-require': 2, // 禁止使用 `new require` + 'no-sparse-arrays': 2, // 禁止稀疏数组 + 'no-trailing-spaces': 1, // 一行结束后面不要有空格 + 'no-unreachable': 2, // 禁止有无法执行的代码 + 'no-unused-expressions': 2, // 禁止无用的表达式 + 'no-use-before-define': 2, // 禁止定义前使用 + 'no-useless-call': 2, // 禁止不必要的 `call` 和 `apply` + 'no-var': 'error', // 禁用 `var` + 'no-with': 2, // 禁用 `with` + 'vue/multi-word-component-names': [ + 'off', + { + ignores: [], + }, + ], + 'vue/no-use-v-if-with-v-for': [ + 'error', + { + allowUsingIterationVar: false, + }, + ], + 'vue/require-v-for-key': ['error'], + 'vue/require-valid-default-prop': ['error'], + }, +} diff --git a/src/components/RayTransitionComponent/index.vue b/src/components/RayTransitionComponent/index.vue index b101201e..27111460 100644 --- a/src/components/RayTransitionComponent/index.vue +++ b/src/components/RayTransitionComponent/index.vue @@ -1,6 +1,10 @@