Sublime Text 无原生“一键折叠所有函数”功能,但可通过Ctrl+Shift+[手动折叠、正则多选后批量折叠,或修改语法文件添加foldingStartMarker/StopMarker实现;默认快捷键Ctrl+K,Ctrl+1仅按缩进折叠。

Sublime Text 本身不提供“一键折叠所有函数定义”的原生命令,但可以通过组合操作或插件实现接近效果。核心在于利用其基于作用域(scope)的代码折叠机制,而非单纯按缩进或括号匹配。
为什么 Ctrl+K, Ctrl+1 折叠不了函数?
Sublime 的默认折叠快捷键 Ctrl+K, Ctrl+1(Windows/Linux)或 Cmd+K, Cmd+1(macOS)只对「缩进层级」生效,对 Python 的 def、JavaScript 的 function 或 =>、C/Java 的 { 块无直接响应——除非语法高亮正确识别了函数作用域,且该语言的 .sublime-syntax 文件明确定义了 foldingStartMarker 和 foldingStopMarker。
- Python 默认语法支持函数折叠(
def行自动视为折叠起点) - JavaScript 默认语法(
JavaScript.sublime-syntax)对function关键字和箭头函数也支持,但需确保没启用旧版JSX或第三方语法包干扰 - TypeScript、Go、Rust 等依赖社区语法包,部分未完整配置折叠规则
手动触发:用 Ctrl+Shift+[ 逐级折叠函数块
这是最可靠、无需插件的方法,前提是当前光标位于函数体内或函数定义行上:
- 将光标放在任意一个
def my_func():或function foo() {行,按Ctrl+Shift+[(Windows/Linux)或Cmd+Shift+[(macOS),会折叠该函数体 - 若想批量操作:先用
Ctrl+F搜索^def |^function |^const.*=.*=>|^[a-zA-Z]+.*=.*=>(正则模式),勾选.*按钮,回车后所有匹配行被选中 → 再按Ctrl+Shift+[,所有选中的函数定义行将各自折叠其对应块 - 注意:该操作依赖语法作用域是否标记了
meta.function类,若搜索结果没被正确高亮(比如全灰),说明当前语法未识别为函数,需换回官方语法包
用 ExpandRegion 插件辅助结构浏览
虽然不直接“折叠函数”,但 ExpandRegion 提供反向思路:快速收拢无关内容,突出函数骨架。
- 安装后,把光标放在文件顶部,连按
Alt+.(默认快捷键),它会逐步收缩到更大粒度的代码块 —— 多次按可退到只剩所有函数签名和类声明 - 比纯折叠更灵活:不会丢失注释、文档字符串、顶层变量等上下文,适合快速扫描逻辑分组
- 缺点:不是真正折叠,不能展开单个函数而不影响其他;需配合
Ctrl+K, Ctrl+J(全部展开)重置
终极方案:改写或切换语法定义(高级)
如果你长期处理某语言(如 TypeScript),且发现默认折叠失效,大概率是语法文件缺失折叠规则。此时可:
- 打开
PackageResourceViewer→ 查看当前语法(如TypeScript/TypeScript.sublime-syntax)→ 搜索folding - 若无
foldingStartMarker,可复制一份到Packages/User/TypeScript.sublime-syntax,添加类似片段:
foldingStartMarker: '^(?:export\\s+)?(?:function|const|let|var)\\s+[a-zA-Z_$][\\w$]*\\s*\\(|^class\\s+[a-zA-Z_$][\\w$]*\\s*\\{|^interface\\s+[a-zA-Z_$][\\w$]*\\s*\\{'
foldingStopMarker: '^\\}'
保存后重启 Sublime。注意正则需严格匹配作用域边界,否则会误折叠注释或字符串内的 {。
实际使用中,80% 场景靠 Ctrl+Shift+[ + 正则多选就能满足大纲浏览需求;真要频繁切换语言结构,建议优先检查语法包是否启用正确版本,而不是强求“一键”。










