• Eslint: JavaScript 语法规则和代码风格检查;
  • Prettier:全局代码格式化;
  • Stylelint: CSS 统一规范和代码检测。

eslint9.x,与以往版本的配置写法不同

一、eslint8.x版本

1. 安装

//eslint 安装
npm install eslint@^8.39.0 -D

//eslint vue插件安装
npm install eslint-plugin-vue@^9.11.0 -D

//eslint 识别ts语法
npm install @typescript-eslint/parser@^6.19.0 -D

//eslint ts默认规则补充
npm install @typescript-eslint/eslint-plugin@^6.19.0 -D

//eslint prettier插件安装
npm install eslint-plugin-prettier@^5.1.3 -D

//用来解决与eslint的冲突
npm install eslint-config-prettier@^9.1.0 -D 

//安装prettier
npm install prettier@^3.2.4 -D

2. 新建.eslintrc.cjs

// .eslintrc.cjs
module.exports = {
    env: {
        browser: true,
        node: true,
        es2021: true,
    },
    parser: "vue-eslint-parser",
    extends: [
        "eslint:recommended", //继承 ESLint 内置的推荐规则
        "plugin:vue/vue3-recommended", // 继承 Vue.js 3 的推荐规则
        "plugin:@typescript-eslint/recommended", //继承 TypeScript ESLint 插件的推荐规则
        "plugin:prettier/recommended", //继承 Prettier 的推荐规则
        "eslint-config-prettier", //关闭 ESLint 中与 Prettier 冲突的规则
    ],
    parserOptions: {
        ecmaVersion: "latest",
        parser: "@typescript-eslint/parser",
        sourceType: "module",
        ecmaFeatures: {
            jsx: true,
        },
    },
    ignorePatterns: ["dist", "node_modules", ".eslintrc.cjs", "commitlint.config.cjs"],
    plugins: ["vue", "@typescript-eslint", "prettier"],
    rules: {
        "vue/multi-word-component-names": "off", // 禁用vue文件强制多个单词命名
        "@typescript-eslint/no-explicit-any": "off", //允许使用any
        "@typescript-eslint/no-this-alias": [
            "error",
            {
                allowedNames: ["that"], // this可用的局部变量名称
            },
        ],
        "@typescript-eslint/ban-ts-comment": "off", //允许使用@ts-ignore
        "@typescript-eslint/no-non-null-assertion": "off", //允许使用非空断言
        "no-console": [
            //提交时不允许有console.log
            "warn",
            {
                allow: ["warn", "error"],
            },
        ],
        "no-debugger": "warn", //提交时不允许有debugger
    },
}

rules更多配置:eslint.org/docs/latest…

3. 新建 .prettierrc

{
    "endOfLine": "auto",
    "printWidth": 120,
    "semi": true,
    "singleQuote": true,
    "tabWidth": 2,
    "trailingComma": "all",
    "bracketSpacing": true
}

4. 新建 .prettierignore

# 忽略格式化文件 (根据项目需要自行添加)
node_modules
dist

5. 重启vscode使配置生效

6. 配置package.json

修改package.json

"scripts": {
    "lint": "eslint src --fix --ext .js,.ts,.vue --report-unused-disable-directives --max-warnings 0"
},

运行 npm run lint,可以看到eslint(prettier/prettier)问题都将被修复

二、eslint9.x版本

1. Eslint

  1. 执行pnpm create @eslint/config 或者 npm init @eslint/config@latest, 将会自动生成eslint.config.js配置文件。默认使用eslint9.x,与以往版本的配置写法不同。

    image.png

    • typescript-eslint: ts-eslint解析器,使 eslint 可以解析 ts 语法,
      • @typescript-eslint/parser: ESLint 默认使用的是 Espree 进行语法解析,所以无法对部分 typescript 语法进行解析,需要替换掉默认的解析器
      • @typescript-eslint/eslint-plugin: 作为 eslint 默认规则的补充,提供了一些额外的适用于 ts 语法的规则
    • eslint-plugin-vue: 这个插件允许我们用 ESLint 检查文件的<template>和,以及文件中的 Vue 代码。
  2. 修改eslint.config.js文件

    import globals from 'globals'; //https://eslint.org/docs/latest/use/configure/language-options
    import pluginJs from '@eslint/js';
    import tseslint from 'typescript-eslint'; //https://typescript-eslint.io/getting-started/
    import pluginVue from 'eslint-plugin-vue'; //https://eslint.vuejs.org/user-guide/
    import vueEslintParser from 'vue-eslint-parser'; // vue文件解析器
    
    export default [
        {
            languageOptions: {
                globals: { ...globals.browser, ...globals.node },
                parser: vueEslintParser, // 使用vue解析器,这个可以识别vue文件
                parserOptions: {
                    ecmaVersion: 'latest',
                    parser: tseslint.parser, // 在vue文件上使用ts解析器
                    sourceType: 'module'
                }
            }
        },
        pluginJs.configs.recommended,
        ...tseslint.configs.recommended,
        ...pluginVue.configs['flat/essential'],
        {
            rules: {
                // override/add rules settings here, such as:
                // 'vue/no-unused-vars': 'error',
            }
        }
    ];
    
  3. 配置ignore

2. Prettier

[官网]

  1. 安装pnpm add prettier eslint-plugin-prettier eslint-config-prettier -D

    • eslint-plugin-prettier将 Prettier 作为 ESLint 规则运行,并将差异报告为单独的 ESLint 问题。
    • eslint-config-prettier
      • 启用prettier/prettier规则。
      • 禁用与该插件有问题的arrow-body-styleprefer-arrow-callback规则
      • 启用eslint-config-prettier配置将关闭与 Prettier 冲突的 ESLint 规则。
  2. 创建配置文件node --eval "fs.writeFileSync('.prettierrc','{}\n')"

  3. 修改 .prettierrc文件如下

    {
        "printWidth": 100,
        "tabWidth": 4,
        "useTabs": false,
        "semi": true,
        "singleQuote": true,
        "quoteProps": "as-needed",
        "jsxSingleQuote": false,
        "trailingComma": "none",
        "bracketSpacing": true,
        "jsxBracketSameLine": false,
        "proseWrap": "always",
        "htmlWhitespaceSensitivity": "ignore",
        "arrowParens": "avoid",
        "endOfLine": "auto"
    }
    
  4. 修改 .eslint.config.js文件如下

import globals from 'globals'; //https://eslint.org/docs/latest/use/configure/language-options
import pluginJs from '@eslint/js';
import tseslint from 'typescript-eslint'; //https://typescript-eslint.io/getting-started/
import pluginVue from 'eslint-plugin-vue'; //https://eslint.vuejs.org/user-guide/
import vueEslintParser from 'vue-eslint-parser'; // vue文件解析器

//关闭所有不必要的或可能与Prettier冲突的规则。https://github.com/prettier/eslint-plugin-prettier?tab=readme-ov-file#configuration-new-eslintconfigjs
import eslintPluginPrettierRecommended from 'eslint-plugin-prettier/recommended';

export default [
    {
        languageOptions: {
            globals: { ...globals.browser, ...globals.node },
            parser: vueEslintParser, // 使用vue解析器,这个可以识别vue文件
            parserOptions: {
                ecmaVersion: 'latest',
                parser: tseslint.parser, // 在vue文件上使用ts解析器
                sourceType: 'module'
            }
        }
    },
    pluginJs.configs.recommended,
    ...tseslint.configs.recommended,
    ...pluginVue.configs['flat/essential'],
    eslintPluginPrettierRecommended, // 放在最后面
    {
        rules: {
            // override/add rules settings here, such as:
            // 'vue/no-unused-vars': 'error',
            'prettier/prettier': [
                'error',
                {
                    // endOfLine: "auto"
                }
            ]
        }
    }
]

3. Stylelint

官网

  1. 执行pnpm create stylelint或者npm init stylelint,将会生成.stylelintrc.json文件, 自动安装stylelintstylelint-config-standard依赖

  2. 执行pnpm add stylelint-config-recommended-less stylelint-config-standard-vue less -D

    • stylelint-config-recommended-lessless的推荐可共享配置规则
    • stylelint-config-standard-vue 可识别vue文件

    从 Stylelint v15 开始,所有与样式相关的规则都已弃用。如果您使用的是 v15 或更高版本,并且未使用这些弃用的规则,则stylelint-config-prettier插件不再是必要的

  3. .stylelintrc.json

    {
        "extends": [
            "stylelint-config-standard",
            "stylelint-config-recommended-less",
            "stylelint-config-standard-vue"
        ]
    }