/** * @program: kicc-ui * @description: ESLint规范检查配置 * 目前跟框架适配情况,支持如下框架: * 原生js-eslint,官方配置文档: https://cn.eslint.org/docs/rules * vue,官方配置文档: https://eslint.vuejs.org/rules * typescript,官方配置文档: https://typescript-eslint.io/rules * @author: wangxiang4 * @create: 2022/4/6 */ const { defineConfig } = require('eslint-define-config'); module.exports = defineConfig({ root: true, env: { browser: true, node: true, es6: true, }, parserOptions: { parser: '@typescript-eslint/parser', ecmaVersion: 2020, sourceType: 'module', jsxPragma: 'React', ecmaFeatures: { jsx: true, }, }, extends: [ 'plugin:vue/vue3-recommended', 'plugin:@typescript-eslint/recommended', ], rules: { /** ----------typescript配置----------- */ '@typescript-eslint/ban-ts-ignore': 'off', '@typescript-eslint/explicit-function-return-type': 'off', '@typescript-eslint/no-explicit-any': 'off', '@typescript-eslint/no-var-requires': 'off', '@typescript-eslint/no-empty-function': 'off', '@typescript-eslint/no-use-before-define': 'off', '@typescript-eslint/ban-ts-comment': 'off', '@typescript-eslint/ban-types': 'off', '@typescript-eslint/no-non-null-assertion': 'off', '@typescript-eslint/explicit-module-boundary-types': 'off', '@typescript-eslint/no-unused-vars': 'off', '@typescript-eslint/quotes': ['error', 'single'], /** ----------eslint配置----------- */ 'no-use-before-define': 'off', 'no-unused-vars': 'off', 'space-before-function-paren': 'off', 'semi': ['error', 'always'], 'prefer-const': 'off', /** ----------vue配置----------- */ 'vue/script-setup-uses-vars': 'error', 'vue/custom-event-name-casing': 'off', 'vue/one-component-per-file': 'off', 'vue/multiline-html-element-content-newline': 'off', 'vue/singleline-html-element-content-newline': 'off', 'vue/attribute-hyphenation': 'off', 'vue/require-default-prop': 'off', 'vue/html-end-tags': 'error', 'vue/html-quotes': ['error', 'double', {'avoidEscape': false}], 'vue/no-multi-spaces': ['error', {'ignoreProperties': false}], 'vue/html-closing-bracket-newline': ['error', { 'singleline': 'never', 'multiline': 'always' }], 'vue/html-indent': ['error', 2, { 'attribute': 1, 'baseIndent': 1, 'closeBracket': 0, 'alignAttributesVertically': true, 'ignores': [] }], 'vue/html-self-closing': ['error', { 'html': { 'void': 'never', 'normal': 'always', 'component': 'always' }, 'svg': 'always', 'math': 'always' }], 'vue/max-attributes-per-line': ['error', { 'singleline': 3, 'multiline': 1 }], 'vue/html-closing-bracket-spacing': ['error', { 'startTag': 'never', 'endTag': 'never', 'selfClosingTag': 'never' }], 'vue/this-in-template': ['error', 'never'], 'vue/component-tags-order': ['error', { 'order': [['script', 'template'], 'style'] }], 'vue/attributes-order': ['error', { 'order': [ 'DEFINITION', 'LIST_RENDERING', 'CONDITIONALS', 'RENDER_MODIFIERS', 'GLOBAL', ['UNIQUE', 'SLOT'], 'TWO_WAY_BINDING', 'OTHER_DIRECTIVES', 'OTHER_ATTR', 'EVENTS', 'CONTENT' ], 'alphabetical': false }], 'vue/no-v-html': 'off', 'vue/multi-word-component-names': 'off', 'vue/first-attribute-linebreak': 'off', 'vue/v-on-event-hyphenation': 'off', } });