0

0

VSCode的Puppeteer a la Code:浏览器自动化脚本调试

P粉986688829

P粉986688829

发布时间:2026-01-06 18:57:08

|

671人浏览过

|

来源于php中文网

原创

应启用 Chrome 调试端口并配置 launch.json、使用 devtools: true 启动、切换至 puppeteer-core 复用外部 Chrome 实例、在 TypeScript 项目中启用 sourceMap 支持。

vscode的puppeteer a la code:浏览器自动化脚本调试

如果您在 VSCode 中使用 Puppeteer 进行浏览器自动化脚本开发,但无法在断点处暂停执行或变量无法正确显示,则可能是由于调试配置未适配 Puppeteer 的无头模式或进程通信机制。以下是解决此问题的步骤:

本文运行环境:MacBook Pro,macOS Sequoia。

一、启用 Chrome 调试端口并配置 launch.json

VSCode 通过 Chrome DevTools Protocol(CDP)连接到 Chromium 实例进行调试,需确保 Puppeteer 启动的浏览器实例暴露调试端口,并被 launch.json 正确引用。

1、在 Puppeteer 启动代码中显式指定 --remote-debugging-port=9222 参数,例如:launch({ headless: false, args: ['--remote-debugging-port=9222'] })

2、在项目根目录创建 .vscode/launch.json,添加类型为 pwa-chrome 的配置项。

3、在配置中设置 urlhttp://localhost:9222,并启用 webRoot 指向源码目录(如 ${workspaceFolder})。

二、使用 puppeteer.launch({ devtools: true }) 启动带开发者工具的实例

该方式可绕过端口配置,直接在 Chromium 窗口中启用 DevTools 界面,使 VSCode 能通过自动发现机制建立调试会话。

1、将 Puppeteer 启动参数中的 headless 设为 false,并添加 devtools: true 选项。

2、运行脚本后,Chromium 将弹出独立窗口并附带完整 DevTools 面板。

3、在 VSCode 中启动调试器,选择 Attach to Process 类型配置,VSCode 将自动列出可用的 CDP 目标并连接。

LobeHub
LobeHub

LobeChat brings you the best user experience of ChatGPT, OLLaMA, Gemini, Claude

下载

三、切换至 puppeteer-core 并复用已运行的 Chrome 实例

避免 Puppeteer 自行管理浏览器生命周期带来的调试上下文丢失问题,改由外部可控的 Chrome 实例承载调试会话。

1、手动启动 Chrome 并监听调试端口:open -n -a "Google Chrome" --args --remote-debugging-port=9222 --no-first-run(macOS)。

2、在代码中使用 puppeteer-core 替代 puppeteer,调用 puppeteer.connect() 方法连接至 ws://localhost:9222/devtools/browser/... WebSocket 地址。

3、从 Chrome 的 chrome://version/ 页面复制完整的 WebSocket URL,粘贴至 connect() 的 browserWSEndpoint 参数中。

四、在 TypeScript 项目中启用 sourceMap 支持

若调试时断点落在编译后 JS 文件而非原始 TS 文件,说明 sourceMap 未被正确加载或映射路径错误。

1、确认 tsconfig.json 中已启用 sourceMap: trueinlineSources: true

2、检查生成的 .js.map 文件是否与同名 JS 文件位于同一目录,且 map 文件中 sources 字段指向正确的 TS 路径(建议使用相对路径)。

3、在 launch.json 的调试配置中添加 sourceMaps: trueoutFiles 数组,明确包含 ./dist/**/*.js 等输出路径。

相关专题

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

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

415

2023.08.07

json是什么
json是什么

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

533

2023.08.23

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

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

310

2023.10.13

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

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

75

2025.09.10

chrome什么意思
chrome什么意思

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

793

2023.08.11

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

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

735

2023.11.06

chrome什么意思
chrome什么意思

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

793

2023.08.11

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

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

735

2023.11.06

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.21

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
go语言零基础开发内容管理系统
go语言零基础开发内容管理系统

共34课时 | 2.6万人学习

第二十三期_前端开发
第二十三期_前端开发

共98课时 | 7.5万人学习

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

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