VSCode全局搜索需手动开启包含子目录、禁用排除设置及dotAll模式:Ctrl+Shift+F打开搜索面板,清空files to exclude并关闭“Use Exclude Settings”,勾选.*按钮启用跨行匹配。

VSCode 的全局搜索和替换功能本身不依赖插件,但默认行为容易让人误以为“没生效”——比如搜索不到 node_modules 里的内容、替换后没保存、正则开启后语法报错却没提示。关键不是“会不会用”,而是“哪些开关必须手动打开”“哪些符号要转义”“哪些场景下 .* 反而匹配不到换行”。
怎么打开真正的全局搜索(含子文件夹)
快捷键 Ctrl+Shift+F(Windows/Linux)或 Cmd+Shift+F(macOS)打开搜索面板,但默认会跳过某些目录。必须检查右上角的 files to include 和 files to exclude:
-
files to include留空表示搜索所有文件;填**/*.js则只搜 JS 文件 -
files to exclude默认包含node_modules, dist, out等,若想搜node_modules,需手动删掉这一项,或改为!node_modules/** - 搜索前务必点一下右上角的
...展开高级选项,确认Use Exclude Settings and Ignore Files是否勾选——取消勾选才能无视.gitignore和settings.json中的files.exclude
Ctrl+H 替换时为什么改了但没保存?
VSCode 的替换操作默认只修改已打开的编辑器标签页,不会自动写入磁盘。即使你点了 Replace All,也只在内存中变更,关闭文件前不会落盘:
- 替换完成后,编辑器左上角标题栏出现圆点(●)表示“有未保存更改”
- 必须手动按
Ctrl+S(或右键标签页选Save),或启用自动保存:File > Auto Save(推荐设为afterDelay) - 若想批量替换并保存所有匹配文件,得先用
Ctrl+Shift+F搜索,再点击搜索结果列表上方的Replace in Files按钮——这个操作才会真正写入文件系统
正则表达式开启后,.* 为什么跨不了行?
VSCode 默认的正则引擎不启用 dotAll 模式(即 . 不匹配换行符),所以 .* 在多行文本中会停在第一个换行处:
- 解决方法:勾选搜索框左侧的
.*按钮(正则模式开关旁),它等价于启用dotAll—— 此时.*才能跨行匹配 - 更安全的写法是显式用
[\s\S]*或(.|\n)*,避免依赖 UI 开关状态 - 注意
$和^默认是行首/行尾锚点,不是整个文档首尾;如需匹配整个文档开头,用\A,结尾用\Z(VSCode 支持 PCRE 风格的这些锚点)
常用正则实战片段(直接复制粘贴可用)
以下示例均需先点击搜索框左侧的 .* 按钮启用正则:
搜索所有 console.log 调用并删除整行:
^console\.log\([^)]*\);?$
替换成 React 函数组件中的 props 解构(原:function Button(props) {...}):
function\s+(\w+)\s*\(\s*(\w+)\s*\)
→ 替换为:const $1 = ({ $2 }) =>
注意 . 在正则中是特殊字符,必须写成 \.;括号、花括号也要转义;$1、$2 是捕获组引用,不能写成 \1。
最常被忽略的一点:VSCode 的搜索正则不支持 /(?i) 这类内联标志,大小写敏感与否只能靠点击 Aa 按钮控制——别在正则里写 (?i)abc,它不会生效。










