// eslint.config.js import antfu from '@antfu/eslint-config' export default antfu({ unocss: true, stylistic: { indent: 2, // 4, or 'tab' quotes: 'single', // or 'double' }, // 使用外部格式化程序来格式化 ESLint 无法处理的文件( .css 、 .html 等) formatters: { css: true, html: true, markdown: 'prettier', }, // https://alloyteam.github.io/eslint-config-alloy/?language=zh-CN&rule=base // https://eslint.vuejs.org/rules/ rules: { 'no-console': 'off', // 强制组件顶级元素的顺序 'vue/block-order': [ 'error', { order: ['template', 'script', 'style'], }, ], 'max-params': ['error', 4], // 代码块嵌套的深度禁止超过 4 层 'max-depth': ['error', 4], // 回调函数嵌套禁止超过 3 层,多了请用 async await 替代 'max-nested-callbacks': ['error', 4], // 禁止使用 Array 构造函数时传入的参数超过一个 // 参数为多个时表示创建一个指定内容的数组,此时可以用数组字面量实现,不必使用构造函数 'no-array-constructor': 'error', // 禁止 if else 的条件判断中出现重复的条件 'no-dupe-else-if': 'error', // 禁止出现空代码块,允许 catch 为空代码块 'no-empty': [ 'error', { allowEmptyCatch: true, }, ], // 禁止出现没必要的字符串连接 'no-useless-concat': 'error', // 禁止使用 var 'no-var': 'error', // 禁止变量申明时用逗号一次申明多个 'one-var': ['error', 'never'], // 必须使用 ... 而不是 Object.assign,除非 Object.assign 的第一个参数是一个变量 'prefer-object-spread': 'error', // 回调函数必须使用箭头函数 'prefer-arrow-callback': 'error', // "stroustrup":强制一致的大括号风格,左括号必须与控制语句在同一行开始,右括号必须独占一行。 'brace-style': ['error', 'stroustrup'], // 强制使用 node 全局变量 process 而不是 require("process") 。 'node/prefer-global/process': 'off', // 对所有控制语句强制执行一致的大括号样式,(只有一行的时候eslint默认是不需要大括号的,这样会降低代码清晰度) 'curly': ['error', 'all'], }, })