Eslint v9 扁平化配置学习

中文官网:ESLint 中文网

安装和配置

根据官网操作:eslint.nodejs.cn/docs/latest...

配置

当我我们运行完pnpm create @eslint/config@latest后会生成一个文件:

eslint.config.mjs:

js 复制代码
import js from '@eslint/js'
import globals from 'globals'
import { defineConfig } from 'eslint/config'

export default defineConfig([
  {
    files: ['**/*.{js,mjs,cjs}'],
    plugins: { js },
    extends: ['js/recommended', 'prettier'],
    languageOptions: { globals: globals.browser },
])

这份文件是个很基础的 flat config 模板

不过注意几个细节 ------ 它里面有一些地方实际上是"旧写法",需要我们手动升级。

1. extends: ['js/recommended'] 在 Flat Config 中正确写法

旧的 .eslintrc.js 里我们用:

js 复制代码
extends: ['eslint:recommended']

但在 Flat Config 里,extends 不再支持这种字符串形式。

👉 取而代之的是直接引入配置对象,例如:

js 复制代码
js.configs.recommended

2. Flat Config 的结构是一个数组

每个数组元素就是一个"配置层",后面的层会覆盖前面的层。

所以配置文件应该像这样:

js 复制代码
import js from '@eslint/js'
import globals from 'globals'
import eslintConfigPrettier from 'eslint-config-prettier'
import { defineConfig } from 'eslint/config'

export default defineConfig([
  // JS 推荐规则
  js.configs.recommended,

  // Prettier 兼容配置(用于关闭与 Prettier 冲突的规则)
  eslintConfigPrettier,

  // 自定义项目规则(在最后)
  {
    files: ['**/*.{js,mjs,cjs}'],
    languageOptions: {
      globals: globals.browser,
    },
    rules: {
      'no-console': 'warn',
      'no-unused-vars': 'error',
    },
  },
])

pretiier安装:安装 · Prettier 中文网
eslint-config-prettier安装:github.com/prettier/es...

3. Flat Config 与旧 .eslintrc 的核心区别

旧版 .eslintrc 新版 eslint.config.js (Flat)
extends 是字符串(如 "eslint:recommended" 直接引入模块配置对象
plugins 是数组 plugins 是对象(key = 名称, value = 插件本体)
自动递归继承 你需要手动合并数组层级
配置分散、难调试 纯 JS/ESM 文件,可逻辑控制

举个例子:

js 复制代码
plugins: ['vue'] // ❌ 旧写法
plugins: { vue: pluginVue } // ✅ 新写法

4. Flat Config 里添加 Vue

js 复制代码
pnpm i eslint-plugin-vue -D

是否要支持vue,在刚开始进行pnpm create @eslint/config@latest时就可以选。

js 复制代码
import js from '@eslint/js'
import pluginVue from 'eslint-plugin-vue'
import globals from 'globals'
import eslintConfigPrettier from 'eslint-config-prettier'
import { defineConfig } from 'eslint/config'

export default defineConfig([
  js.configs.recommended,
  pluginVue.configs['flat/essential'], // Vue 推荐配置
  eslintConfigPrettier,

  {
    files: ['**/*.{js,vue}'],
    languageOptions: {
      globals: globals.browser,
    },
    rules: {
      'no-console': 'warn',
      'vue/multi-word-component-names': 'off', // 禁用多词规则
    },
  },
])

5.配置typescript支持

官网:Getting Started | typescript-eslint

js 复制代码
// eslint.config.mjs
// @ts-check
import eslint from '@eslint/js'
import pluginVue from 'eslint-plugin-vue'
import tseslint from 'typescript-eslint'
import eslintConfigPrettier from 'eslint-config-prettier'
import globals from 'globals'
import { defineConfig } from 'eslint/config'

export default defineConfig([
  // 基础 JS 规则
  eslint.configs.recommended,

  // TypeScript 推荐规则
  ...tseslint.configs.recommended, // 或 strict, stylistic

  // Vue 规则
  pluginVue.configs['flat/essential'],

  // Prettier 关闭冲突规则
  eslintConfigPrettier,

  // 自定义规则
  {
    files: ['**/*.{js,ts,vue}'],
    languageOptions: {
      parser: tseslint.parser, // 用 ts parser 支持 <script lang="ts">
      parserOptions: {
        projectService: true, // 如果你启用了 typed linting
        tsconfigRootDir: import.meta.dirname,
      },
      globals: globals.browser,
    },
    rules: {
      'no-console': 'warn',
      'no-unused-vars': 'error',
      'vue/multi-word-component-names': 'off',
    },
  },
])
相关推荐
一 乐7 小时前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
bitbitDown7 小时前
从零打造一个 Vite 脚手架工具:比你想象的简单多了
前端·javascript·面试
liangshanbo12158 小时前
CSS 数学函数完全指南:从基础计算到高级动画
前端·css
码上成长9 小时前
GraphQL:让前端自己决定要什么数据
前端·后端·graphql
冴羽9 小时前
为什么在 JavaScript 中 NaN !== NaN?背后藏着 40 年的技术故事
前端·javascript·node.js
久爱@勿忘9 小时前
vue下载项目内静态文件
前端·javascript·vue.js
前端炒粉9 小时前
21.搜索二维矩阵 II
前端·javascript·算法·矩阵
合作小小程序员小小店9 小时前
web网页开发,在线%台球俱乐部管理%系统,基于Idea,html,css,jQuery,jsp,java,ssm,mysql。
java·前端·jdk·intellij-idea·jquery·web
不爱吃糖的程序媛10 小时前
Electron 应用中的系统检测方案对比
前端·javascript·electron
泷羽Sec-静安10 小时前
Less-9 GET-Blind-Time based-Single Quotes
服务器·前端·数据库·sql·web安全·less