Sublime Text 默认不支持 PHP 控制结构(如 if、foreach)的智能折叠,因其语法文件未定义相应折叠点;推荐安装“PHP Fold”插件实现完整折叠功能。
Sublime Text 默认不支持 PHP 区块的智能折叠(比如 if、function、class 等结构),必须手动配置语法作用域或安装插件才能实现可靠折叠。
Sublime Text 的代码折叠基于语法高亮产生的 scope,而非缩进层级。PHP 默认的 PHP.tmLanguage(或新版的 PHP.sublime-syntax)对控制结构(如 if、for、while)未定义折叠点,所以即使代码缩进正确,Ctrl+Shift+[ 也无效。
Ctrl+Shift+P → Developer: Show Scope Name 查看光标所在位置的完整 scope,常见 PHP 结构 scope 如:meta.function.php、meta.class.php、meta.block.if.php
foldingStartMarker 和 foldingStopMarker(在 .sublime-syntax 或 .tmLanguage 文件中),折叠才生效class 和 function 通常有折叠支持,但 if/foreach 等几乎都没有“PHP Fold” 是目前最轻量且维护良好的方案,它不替换语法高亮,而是通过监听 view 事件,动态注入折叠区域(folding regions),对 if、else、foreach、switch、try 等全部支持。
PHP Fold 并安装Ctrl+Shift+[(折叠)和 Ctrl+Shift+](展开)if 内套 foreach),且不会干扰已有的 class/function 折叠source.php 作用域,若你用的是 PHP (HTML) 混合语法(即 .php 文件含 HTML),需确保文件被识别为纯 PHP —— 可右下角点击语法名,选 PHP 而非 PHP (HTML)
如果你坚持不用插件,可直接编辑 PHP 语法定义,添加折叠标记。但 Sublime Text 4 使用 YAML 格式的 .sublime-syntax,修改门槛较高,且升级后易被覆盖。
以 Sublime Text 4 自带的 PHP.sublime-syntax 为例,在其 contexts 下追加类似规则(仅示意,不可直接复制使用):
- match: '\b(if|else|elseif|for|foreach|while|switch|case|default|try|catch|finally)\b'
scope: meta.block.$1.php
push:
- meta_scope: meta.block.$1.php
- match: '\}'
pop: true
.subl
ime-syntax 的 push/pop 机制,并准确匹配起止符号if 可能无花括号(if ($x): ... endif;),这种替代语法需额外处理,极易出错真正稳定的 PHP 折叠,离不开插件或深度定制。多数人卡在“为什么缩进对了却折不了”,本质是 scope 缺失,而不是操作不对。别纠结快捷键是否按准,先确认折叠能力是否存在。