0

0

javascript如何调试代码_浏览器开发者工具有何技巧【教程】

狼影

狼影

发布时间:2026-01-27 17:23:02

|

746人浏览过

|

来源于php中文网

原创

JavaScript调试应优先使用断点和作用域面板:确保源码加载且sourcemap正确,善用条件断点、XHR/事件监听断点,结合Scope面板查变量作用域与this值,配合Network面板排查请求问题。

javascript如何调试代码_浏览器开发者工具有何技巧【教程】

JavaScript 调试不靠 console.log 盲打,关键在用对断点和作用域面板——绝大多数卡壳问题,其实 3 分钟内就能定位到 undefinedthis 绑定错的地方。

怎么在源码里下断点才真正生效

直接点击行号左侧设断点最常用,但容易忽略两个前提:源码必须已加载(webpackVite 项目要等 Sources 面板里显示的是原始 .ts/.jsx 文件,不是打包后的 bundle.js);且脚本不能被 eval() 动态执行(否则断点会灰掉)。如果断点变浅灰色、点击无响应,大概率是 sourcemap 没配好或代码被压缩后未映射。

实操建议:

  • Chrome 中按 Ctrl+P(Win)或 Cmd+P(Mac)快速搜文件名,避免在混乱的 webpack:// 目录里手动翻
  • 右键行号 → Add conditional breakpoint,填入 user.id === 123 这类表达式,比在代码里写 ifdebugger 干净得多
  • 遇到异步回调(如 setTimeoutPromise.then),优先用 XHR/fetch BreakpointsEvent Listener Breakpoints → Timer,而不是盲目在回调里加断点

为什么 watch 表达式总显示 undefined

Watch 面板里输 data.list 却报 ReferenceError,通常不是变量不存在,而是当前断点停在了错误的作用域。比如函数 A 调用函数 B,断点停在 B 里,却想看 A 的局部变量 items——它根本不在 B 的词法环境里。

立即学习Java免费学习笔记(深入)”;

Toolplay
Toolplay

一站式AI应用聚合生成平台

下载

实操建议:

  • 看右侧面板的 Scope 区域,展开 ClosureFunctionGlobal,确认目标变量在哪一层;this 的值也在这一栏实时显示
  • Watch 里不要输带副作用的表达式,例如 arr.pop(),每次刷新 Watch 都会执行一次,导致数据异常
  • 想观察对象深层属性变化?用 console.table(data) 替代反复展开,尤其适合数组或键值结构清晰的对象

network 面板里找不到 fetch 请求

代码写了 fetch('/api/user'),但 Network 面板过滤 fetch/XHR 却为空,常见原因是请求被拦截(如 Service Worker 缓存)、跨域失败静默丢弃,或请求发到了非 http:// 协议(如 file:// 协议下 fetch 被浏览器禁止)。

实操建议:

  • 勾选 Preserve log,防止页面跳转后请求记录清空
  • 右键某条请求 → Copy → Copy as fetch,粘贴到控制台直接复现,排除前端逻辑干扰
  • 若看到请求状态为 (canceled),打开 Initiator 列,点进去看是哪行 JS 触发的——常是 abortController.abort()路由跳转时未清理请求

真正难调的从来不是语法错误,而是变量在某个闭包里被意外覆盖、async/await 链中某处没 catch、或者 localStorage 里存了个 undefined 字符串——这些都得靠断点停住那一刻的 ScopeCall Stack 来揪出来,而不是靠重刷页面猜。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

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

826

2023.08.11

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

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

742

2023.11.06

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

775

2023.08.22

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

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

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1498

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

623

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

592

2024.03.22

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

9

2026.01.27

热门下载

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

精品课程

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

共58课时 | 4.2万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

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

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