0

0

如何在VSCode中配置ESLint进行代码检查?【教程】

夜晨

夜晨

发布时间:2026-01-20 20:16:02

|

217人浏览过

|

来源于php中文网

原创

VSCode 不自带 ESLint,需手动安装官方扩展并配置本地依赖与规则文件;未正确安装 eslint 或插件、packageManager 设置错误、文件未匹配 glob 等均会导致检查失效。

如何在vscode中配置eslint进行代码检查?【教程】

VSCode 本身不自带 ESLint,必须手动安装扩展并配置项目级规则,否则打开文件时不会触发任何检查。

安装 ESLint 扩展和本地依赖

VSCode 的 ESLint 功能由 ESLint 官方扩展提供,但它只负责调用项目中已安装的 eslint 包,不内置引擎。 如果你只装了扩展但没在项目里装 eslint,编辑器会报错: Failed to load plugin 'xxx' declared in '.eslintrc.js': Cannot find module 'eslint-plugin-xxx'
  • 在项目根目录运行:
    npm init -y && npm install eslint --save-dev
  • 推荐同时安装常用插件(按需):eslint-plugin-react@typescript-eslint/eslint-plugin
  • VSCode 中搜索安装扩展:ESLint(作者:Microsoft)
  • 确保扩展设置中启用了“Auto Fix on Save”(如需保存时自动修复)

配置 .eslintrc.* 文件

ESLint 默认查找 .eslintrc.js.eslintrc.cjs.eslintrc.json 等,优先级从高到低。推荐用 .eslintrc.cjs(兼容 ES 模块与 CommonJS,尤其在 Node ≥14 + TypeScript 项目中更稳)。
  • 不要直接复制网上零散规则拼凑,先用官方初始化:
    npx eslint --init
  • 回答几个问题后,它会生成基础配置(比如是否用 TypeScript、React、Prettier 等)
  • 常见关键字段:
    • env:指定环境(browser: truenode: true
    • extends:继承预设(eslint:recommendedplugin:react/recommended
    • plugins:声明插件(["react"]),否则 extends 中的 plugin:xxx 会报错
    • rules:覆盖具体规则("no-console": "warn"

VSCode 设置与常见失效原因

即使配置正确,也常因以下原因导致“没反应”:
  • eslint.packageManager 设置错误:如果用 pnpmyarn,需在 VSCode 设置中显式指定,否则找不到本地 eslint
  • 工作区未启用 ESLint:检查右下角状态栏是否有 ESLint 图标;没有则点击它 → “Enable ESLint for this workspace”
  • 文件未被 glob 匹配:默认只检查 */.{js,jsx,ts,tsx},若你写的是 .vue.svelte,需在 eslint.validate 中补充
  • 使用了 overrides 但路径匹配失败:比如 files: ["src/*/"] 写成 files: ["src/**"],后者不匹配文件
{
  "eslint.validate": ["javascript", "javascriptreact", "typescript", "typescriptreact"]
}

与 Prettier 冲突怎么处理?

Prettier 负责格式化,ESLint 负责逻辑/风格检查,二者定位不同,但规则重叠(如引号、分号)会导致冲突。
  • 不要用 eslint-config-prettier 关闭所有 ESLint 格式规则(太粗暴),而是配合 prettier 插件做协同:
    • 安装:npm install --save-dev prettier eslint-config-prettier eslint-plugin-prettier
    • .eslintrc.cjsextends 末尾加:"plugin:prettier/recommended"
    • 确保 plugin:prettier/recommended 放在 extends 最后——它会把其他规则中和 Prettier 冲突的部分设为 "off"

真正容易被忽略的是:VSCode 的 ESLint 扩展默认只在打开的文件中生效,对未打开的文件(比如刚 git pull 下来的)不会主动扫描。需要手动右键文件 → “ESLint: Fix all auto-fixable Problems”,或配置 eslint.runonSaveonType

Teleporthq
Teleporthq

一体化AI网站生成器,能够快速设计和部署静态网站

下载

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

413

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

310

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

75

2025.09.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

510

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5286

2023.08.17

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 6.8万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号