0

0

VSCode如何快速进行代码调试与错误排查【教程】

夜晨

夜晨

发布时间:2026-01-25 18:45:36

|

481人浏览过

|

来源于php中文网

原创

VSCode调试失败主因是launch.json配置错误:program路径错、cwd不匹配、env格式错误;断点失效多因sourceMap未开启或outFiles路径不对;启动即崩溃需设stopOnEntry或--trace-warnings。

vscode如何快速进行代码调试与错误排查【教程】

VSCode 调试不是“点一下就跑起来”,关键在于 launch.json 配置是否匹配当前运行环境和入口文件——配错路径、漏掉 env 或用错 program,调试器根本连不上进程。

为什么断点不生效?检查 sourceMapoutFiles 是否对齐

TypeScript、Vue 或 Webpack 项目里,断点打在 .ts/.vue 文件却跳过,大概率是调试器找不到源码映射。VSCode 默认只读取生成代码,不自动回溯原始文件。

  • TS 项目必须确保编译时开启 "sourceMap": truetsconfig.json),且 launch.jsonoutFiles 指向正确输出目录,例如 ["${workspaceFolder}/dist/**/*.js"]
  • Vue CLI 项目建议用 vue-cli-service serve 启动,并在 launch.json 中设置 "runtimeExecutable": "npm""runtimeArgs": ["run", "serve"],避免直接调试打包后代码
  • Chrome 调试时若提示 “No source map found”,检查 Network 面板中 .js.map 文件是否 404,常见于 webpack devtool 设为 hidden-source-map 或未启用 inlineSourceMap

launch.json 常见错误配置项与修正方式

绝大多数调试失败源于 launch.json 的三个字段:路径没写对、运行时选错、参数传反了。它不像 package.json 那样有 schema 校验,错一个字母就静默失败。

PhotoScissors
PhotoScissors

免费自动图片背景去除

下载
  • program 必须是可执行的 JS 入口(如 "${workspaceFolder}/src/index.js"),不能是 .ts 文件(除非配了 ts-node
  • cwd 决定 process.cwd() 返回值,影响相对路径读取,Node.js 项目常因 cwd 错误导致 require 找不到模块
  • env 是对象,不是字符串,写成 "env": "NODE_ENV=development" 会完全失效,正确写法是 "env": {"NODE_ENV": "development"}
  • 调试子进程(如 child_process.fork)需额外加 "console": "integratedTerminal" 并手动 attach,VSCode 不自动追踪 fork 出的进程

如何快速定位“程序启动就崩溃”类错误?

这类问题往往发生在 node 进程启动瞬间,还没走到第一个断点就退出,常规断点无效。必须让调试器在第一行就接管。

  • launch.json 中添加 "stopOnEntry": true,强制在入口文件第一行暂停
  • 如果崩溃来自依赖模块(比如 require('xxx') 报错),启用 Node.js 的 --trace-warnings:在 runtimeArgs 加入 "--trace-warnings",错误堆栈会包含完整 require 链
  • Windows 下遇到 EPERMEACCES 类错误,大概率是杀毒软件拦截了调试端口(默认 9229),临时关闭实时防护或换端口("port": 9230
  • 使用 node --inspect-brk 启动后,再在 VSCode 里选择 “Attach to Node Process”,比 launch 更早介入生命周期

真正卡住人的从来不是“怎么设断点”,而是搞不清当前调试的是哪段代码、哪个进程、哪个工作目录——console.log(process.pid)console.log(process.cwd()) 在怀疑环境错乱时,比任何文档都管用。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

418

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

823

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

741

2023.11.06

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

466

2023.11.27

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

58

2026.01.23

热门下载

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

精品课程

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

共42课时 | 7.1万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.5万人学习

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

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