如何解决vscode常见的性能与卡顿问题【教程】

发布时间 - 2026-01-25 00:00:00    点击率:
VS Code卡顿主因是扩展、设置或工作区配置失控;禁用GitLens等高负载扩展、配置files.watcherExclude、优化TS语言服务、限制工作区范围可显著改善。

VS Code 卡顿,通常不是硬件问题,而是扩展、设置或工作区配置失控导致的——关掉几个扩展,往往比升级内存更有效。

禁用可疑扩展:从 GitLensESLintPrettier 开始排查

这些扩展功能强,但默认开启全项目监听,尤其在大型仓库中会持续扫描文件、触发格式化或语法检查,CPU 占用飙升。真实案例中,禁用 GitLens 后编辑器响应延迟从 800ms 降到 40ms。

  • Ctrl+Shift+

    P
    (Windows/Linux)或 Cmd+Shift+P(macOS),输入 Extensions: Show Enabled Extensions 查看已启用列表
  • 逐个禁用高风险扩展:GitLensESLintPrettierAuto Rename TagPath Intellisense
  • 每次禁用后重启 VS Code,用 Ctrl+Shift+PDeveloper: Toggle Developer Tools 观察 Performance 标签页的主线程活动
  • 若某扩展禁用后卡顿消失,不要直接卸载,先查其设置:比如 GitLens 可设 "gitlens.advanced.caching.enabled": false 或限制作用范围

关闭不必要的文件监视:重点调 files.watcherExcludesearch.followSymlinks

VS Code 默认用底层文件系统监听(如 chokidar)追踪变化,一旦项目含 node_modulesdist.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" 更激进,但可能影响开发体验
  • 如果项目用 pnpmyarn 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)直接跳转定义,不依赖全局索引——前提是已正确配置 pathsbaseUrltsconfig.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版本功能详解