0

0

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

紅蓮之龍

紅蓮之龍

发布时间:2026-01-25 17:59:35

|

578人浏览过

|

来源于php中文网

原创

VS Code卡顿主因是扩展、设置或工作区配置失控;禁用GitLens等高负载扩展、配置files.watcherExclude、优化TS语言服务、限制工作区范围可显著改善。

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

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,极易引发内存溢出与响应延迟。

CreateWise AI
CreateWise AI

为播客创作者设计的AI创作工具,AI自动去口癖、提交亮点和生成Show notes、标题等

下载
  • 在工作区设置中加入:
  • {
      "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,四者叠加会在每次保存时触发多次解析与重写。这时候删掉一行配置,比换电脑管用。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

49

2026.02.13

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

196

2026.02.25

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

42

2026.03.13

json数据格式
json数据格式

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

457

2023.08.07

json是什么
json是什么

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

549

2023.08.23

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

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

337

2023.10.13

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

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

82

2025.09.10

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

888

2023.07.31

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共48课时 | 10.7万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

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

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