如何解决vscode常见的性能与卡顿问题【教程】
发布时间 - 2026-01-25 00:00:00 点击率:次VS Code卡顿主因是扩展、设置或工作区配置失控;禁用GitLens等高负载扩展、配置files.watcherExclude、优化TS语言服务、限制工作区范围可显著改善。
VS Code 卡顿,通常不是硬件问题,而是扩展、设置或工作区配置失控导致的——关掉几个扩展,往往比升级内存更有效。
禁用可疑扩展:从 GitLens、ESLint、Prettier 开始排查
这些扩展功能强,但默认开启全项目监听,尤其在大型仓库中会持续扫描文件、触发格式化或语法检查,CPU 占用飙升。真实案例中,禁用 GitLens 后编辑器响应延迟从 800ms 降到 40ms。
- 按
Ctrl+Shift+(Windows/Linux)或
P
Cmd+Shift+P(macOS),输入Extensions: Show Enabled Extensions查看已启用列表 - 逐个禁用高风险扩展:
GitLens、ESLint、Prettier、Auto Rename Tag、Path Intellisense - 每次禁用后重启 VS Code,用
Ctrl+Shift+P→Developer: Toggle Developer Tools观察 Performance 标签页的主线程活动 - 若某扩展禁用后卡顿消失,不要直接卸载,先查其设置:比如
GitLens可设"gitlens.advanced.caching.enabled": false或限制作用范围
关闭不必要的文件监视:重点调 files.watcherExclude 和 search.followSymlinks
VS Code 默认用底层文件系统监听(如 chokidar)追踪变化,一旦项目含 node_modules、dist、.git 或大量构建产物,监听器会频繁触发并阻塞 UI 线程。
- 在用户设置(
settings.json)中添加:
{
"files.watcherExclude": {
"**/node_modules/**": true,
"**/dist/**": true,
"**/build/**": true,
"**/.git/**": true,
"**/coverage/**": true
},
"search.followSymlinks": false
}
files.watcherExclude 是硬性过滤,比 files.exclude 更早生效;注意路径通配符必须用双星号 **,单星号无效search.followSymlinks 设为 false 可避免搜索时遍历符号链接目录(常见于 monorepo 的 packages 链接)"files.useExperimentalFileWatcher": true(仅限 VS Code 1.85+),启用基于 inotify/fsevents 的轻量监听器限制 TypeScript/JavaScript 语言服务负载:调整 typescript.preferences.includePackageJsonAutoImports
TypeScript 语言服务器(TSServer)是后台最常“拖慢”VS Code 的进程之一,尤其在含多个 tsconfig.json 或大量依赖的项目中。它默认自动索引所有 node_modules/@types,极易引发内存溢出与响应延迟。
- 在工作区设置中加入:
{
"typescript.preferences.includePackageJsonAutoImports": "auto",
"typescript.preferences.suggestAutoImports": false,
"typescript.preferences.useAliasesForBuiltinTypes": false
}
"auto" 表示只在显式 import 时才补全,而非全局预加载;设为 "off" 更激进,但可能影响开发体验pnpm 或 yarn pnp,务必确认 typescript.tsdk 指向工作区本地安装的 TS 版本,否则会 fallback 到 VS Code 内置旧版,兼容性差且更卡TypeScript: Restart TS Server 立即生效,无需重启编辑器避免工作区过大:不用单个窗口打开整个 monorepo 根目录
VS Code 不是 IDE,它本质是“多文件编辑器 + 插件生态”。把包含 20+ 子包、数万文件的 monorepo 根目录直接作为工作区打开,等于让所有扩展和语言服务同时处理全部内容,必然卡顿。
- 改用
File → Add Folder to Workspace…,只添加当前正在开发的子包目录(如packages/api) - 配合
workbench.editor.enablePreview设为false,防止单击文件时反复覆盖标签页,减少 DOM 渲染压力 - 若需跨包跳转,用
Ctrl+Click(或Cmd+Click)直接跳转定义,不依赖全局索引——前提是已正确配置paths和baseUrl在tsconfig.json中 - 对纯前端项目,禁用
npm扩展(它会扫描整个node_modules生成依赖图谱),改用终端手动运行npm ls
真正难调的卡顿,往往藏在“看起来无害”的组合里:比如 ESLint + Prettier + Format on Save + 大型 prettier.config.js,四者叠加会在每次保存时触发多次解析与重写。这时候删掉一行配置,比换电脑管用。
# linux
# javascript
# java
# vscode
# js
# 前端
# git
# json
# node
# typescript
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
香港服务器建站指南:免备案优势与SEO优化技巧全解析
Laravel定时任务怎么设置_Laravel Crontab调度器配置
简历没回改:利用AI润色让你的文字更专业
如何挑选最适合建站的高性能VPS主机?
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
iOS中将个别页面强制横屏其他页面竖屏
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
三星网站视频制作教程下载,三星w23网页如何全屏?
如何在 React 中条件性地遍历数组并渲染元素
如何在Ubuntu系统下快速搭建WordPress个人网站?
如何在企业微信快速生成手机电脑官网?
文字头像制作网站推荐软件,醒图能自动配文字吗?
如何在宝塔面板创建新站点?
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
jQuery中的100个技巧汇总
,交易猫的商品怎么发布到网站上去?
如何在IIS中配置站点IP、端口及主机头?
javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】
电商网站制作价格怎么算,网上拍卖流程以及规则?
,怎么在广州志愿者网站注册?
免费视频制作网站,更新又快又好的免费电影网站?
如何用腾讯建站主机快速创建免费网站?
晋江文学城电脑版官网 晋江文学城网页版直接进入
七夕网站制作视频,七夕大促活动怎么报名?
大连 网站制作,大连天途有线官网?
黑客如何利用漏洞与弱口令入侵网站服务器?
高防服务器租用指南:配置选择与快速部署攻略
黑客入侵网站服务器的常见手法有哪些?
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
原生JS实现图片轮播切换效果
成都网站制作公司哪家好,四川省职工服务网是做什么用?
浅谈javascript alert和confirm的美化
Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧
如何在阿里云香港服务器快速搭建网站?
C语言设计一个闪闪的圣诞树
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
微信公众帐号开发教程之图文消息全攻略
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
JavaScript模板引擎Template.js使用详解
Laravel如何配置Horizon来管理队列?(安装和使用)
浅谈redis在项目中的应用
深圳网站制作培训,深圳哪些招聘网站比较好?
如何快速打造个性化非模板自助建站?
JavaScript Ajax实现异步通信
EditPlus中的正则表达式实战(5)
如何用免费手机建站系统零基础打造专业网站?
北京专业网站制作设计师招聘,北京白云观官方网站?
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解


