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',
    },
  },
])
相关推荐
marsh02064 分钟前
49 openclaw故障排查:系统异常时的诊断方法
服务器·前端·青少年编程·ai·php·技术美术
Maimai108085 分钟前
前端如何落地 SSE:从实时评论到可复用的实时数据 Hook
前端·javascript·react.js·前端框架·web3·状态模式·webassembly
冴羽18 分钟前
JavaScript 9 个先有库再有 API 的故事
前端·javascript
欧阳天风20 分钟前
vue+vite生产环境更新提示
前端·javascript·vue.js
靠谱品牌推荐官23 分钟前
【架构实战】如何设计一套原生支持 GEO 大模型爬虫语义索引的 HTML5/CSS3 纯净白盒前端架构?
前端·爬虫·架构
谢小飞1 小时前
Three.js三球轮播沉浸式落地页开发
前端·three.js
之歆1 小时前
DAY_14JavaScript DOM 进阶:HTML DOM 接口、事件监听与经典交互实战
开发语言·前端·javascript·html·ecmascript·交互
江南十四行1 小时前
从Web开发到网络通信的知识梳理
前端
肖老师xy1 小时前
Vue3+OpenStreetMap实现地理围栏
前端
KaMeidebaby1 小时前
卡梅德生物技术快报|Fab 抗体文库构建标准化实验流程与数据复盘
服务器·前端·数据库·人工智能·算法