0

0

在VSCode中如何使用代码折叠功能保持编辑器整洁【教程】

夢幻星辰

夢幻星辰

发布时间:2026-01-26 16:33:11

|

519人浏览过

|

来源于php中文网

原创

VSCode代码折叠默认开启,按语言语法和内置提供器规则折叠函数、类、注释等;支持#region自定义区域;快捷键为Ctrl+Shift+[ / ](macOS为Cmd),需注意输入法、键盘布局及焦点位置;折叠仅视觉生效,不影响代码分析与执行。

在vscode中如何使用代码折叠功能保持编辑器整洁【教程】

VSCode 的代码折叠功能默认开启,不需要额外安装插件,但很多开发者没意识到它对不同语言、不同结构的折叠行为差异很大——关键不是“能不能折”,而是“按什么规则折”和“怎么让折叠更符合你的工作流”。

哪些代码块默认可折叠

VSCode 基于语言语法(Language Server)和内置折叠提供器(folding provider)决定可折叠范围。常见支持:

  • functionifforwhile 等语句块(JavaScript/TypeScript/Python/Go 等主流语言均支持)
  • 类(class)、接口(interface)、命名空间(namespace)等声明体
  • 注释块(以 /* ... */ 包裹的多行注释,部分语言如 C/C++/Java 支持;Python 的三引号字符串 """...""" 默认不折叠,需配置)
  • JSON/YAML 文件中对象和数组层级(VSCode 1.80+ 原生支持)

折叠快捷键与鼠标操作不一致?检查键盘映射

默认快捷键是 Ctrl+Shift+[(折叠)和 Ctrl+Shift+](展开),但在 macOS 上对应 Cmd+Shift+[。容易出错的点:

  • 输入法处于中文状态时,[] 键可能被拦截,导致快捷键失效
  • 某些键盘布局(如 Dvorak 或自定义键位)下,[/] 物理位置变化,但 VSCode 仍按标准键位绑定
  • 终端或调试控制台聚焦时,快捷键会作用于终端而非编辑器 —— 确保光标在代码编辑区

可在设置中搜索 folding,确认 editor.foldingtrue,并检查 keybindings.json 是否被其他扩展覆盖了折叠快捷键。

自定义折叠区域:用 // #region// #endregion

当语法级折叠不够用(比如想把一组相关配置、一段临时注释掉的逻辑、或跨函数的业务模块收起),VSCode 支持手动标记折叠区域:

SuperDesign
SuperDesign

开源的UI设计AI智能体

下载
// #region API 配置
const baseUrl = 'https://api.example.com';
const timeout = 5000;
// #endregion

注意细节:

  • 必须成对出现,且 #region#endregion 后面的描述文本可选,但不能换行
  • 支持嵌套,但深度过大会影响性能(建议不超过 3 层)
  • JavaScript/TypeScript/Python/C# 等语言原生支持;CSS/HTML 需要安装扩展(如 Region Folder)才能启用
  • 区域折叠优先级高于语法折叠 —— 即使内部有 if 块,也会被整个 #region 包裹住

折叠后跳转困难?别忽略折叠状态对导航的影响

折叠本身不影响代码执行或 LSP 功能(如跳转定义、查找引用),但会影响以下操作:

  • Ctrl+F 查找默认只在展开内容中匹配,折叠区域内的文本不会高亮或定位
  • 大纲视图(Outline)仍显示所有符号,但点击折叠后的 function 会直接跳到首行,而非展开它
  • 使用 Ctrl+G 跳转行号时,如果目标行在折叠块内,VSCode 会自动展开该区域 —— 这是默认行为,不可关闭
  • Git 差异对比中,折叠状态不保存,每次打开文件都会重置为默认折叠状态

真正容易被忽略的是:折叠只是视觉操作,不改变 AST 结构,所以 ESLint、Prettier 等工具完全感知不到你是否折叠了某段代码 —— 别误以为“折起来就等于暂时禁用”。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

778

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

686

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

769

2023.07.25

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

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

740

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1445

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

571

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

581

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

752

2023.08.11

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

31

2026.01.26

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 24万人学习

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

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