sublime Text 正则搜索替换可高效重构代码:①函数调用格式转换如 getUserInfo(id)→getUserInfo({ id });②安全删除或注释 console.log;③限定作用域重命名变量;④跨行匹配多行注释;⑤复用缩进处理 if 块。

sublime text 的搜索与替换功能配合正则表达式,能极大提升代码重构效率。关键不是学会所有语法,而是掌握几个高频、安全、可复用的模式。
快速定位并统一替换函数调用格式
比如把 getUserInfo(id) 改成 getUserInfo({ id }),或批量为旧版回调函数添加 async/await。
- 打开「Find → Replace」(Ctrl+H / Cmd+H)
- 勾选右下角的 .*(启用正则)和 ☑ In Selection(如只改当前文件或选中区域)
- 查找框填:
getUserInfo(([^)]+))→ 匹配括号内任意非右括号内容,并捕获为组1 - 替换框填:
getUserInfo({ $1 })→$1引用第一个捕获组,前后加花括号和空格
安全删除无用 console.log 且保留注释上下文
直接搜 console.log 全删容易误伤,比如删掉被注释掉的、或写在字符串里的。
- 查找:
^s*console.log([^)]*);s*$→^行首,s*可选空白,;行尾,确保是独立语句 - 替换留空即可;想转成注释可填:
// console.log$0($0表示整行匹配内容) - 先点 Find All 预览,确认全是目标再点 Replace All
批量重命名变量(需谨慎,建议配合作用域限定)
正则无法理解语义,所以要尽量缩小范围——比如只在 .js 文件中,且限定在函数体内。
- 先用「Find in Files」(Ctrl+Shift+F)限定路径:
src/**/*.js - 查找:
(var|let|const)s+oldNameb→ 确保是声明语句中的变量名(b防止匹配到oldNameList) - 替换:
$1 newName($1保留原关键字) - 更稳妥的做法:先用「Find All」人工检查前几处,确认无误再批量操作
跨行匹配与结构化替换(处理多行 if / for / 注释块)
默认正则不跨行,需开启 (?s) 模式(dotall),让 . 匹配换行符。
- 查找多行注释块:
(?s)/**[sS]*?*/→[sS]是兼容写法,等价于.+(?s),?让*非贪婪 - 替换为单行 JSDoc:
/** @deprecated */ - 处理缩进敏感结构(如 if 块)时,可在查找中用
^s*捕获缩进,替换时复用:$1if (condition) {
基本上就这些。正则不是越复杂越好,清晰、可读、可验证才是关键。每次批量改之前,务必先 Find All 看一遍匹配结果——少一次误操作,省半天回滚时间。