0

0

javascript调试技巧有哪些_如何用控制台快速排错

狼影

狼影

发布时间:2026-01-09 20:04:02

|

800人浏览过

|

来源于php中文网

原创

console.log 不够用,应优先使用 console.table()、console.group()、console.time()、console.assert() 等结构化调试方法,并结合断点调试、全局错误监听、console.dir 和 $0 等 dom 调试技巧。

javascript调试技巧有哪些_如何用控制台快速排错

console.log 不够用?先搞清它的替代方案

直接写 console.log 容易污染代码、漏删、掩盖真实执行路径。现代调试更依赖条件性、结构化和可追溯的输出方式。

  • console.table() 适合查看数组或对象列表,比层层展开 console.log 更直观
  • console.group()console.groupEnd() 能折叠日志块,配合异步操作或循环时逻辑更清晰
  • console.time() / console.timeEnd() 对比两段逻辑耗时,比手动记时间戳靠谱得多
  • console.assert(condition, msg) 只在条件为 false 时输出,适合轻量级运行时断言

打断点比 console 更准:Chrome DevTools 的实用技巧

很多问题靠输出猜不到,比如变量被谁改了、异步回调没进、Promise 状态卡在哪——这时候必须进 Debugger。

  • 在 Sources 面板里点击行号左侧设断点,支持条件断点:event.target.id === 'submit-btn'
  • debugger 语句是硬编码断点,只在开发环境保留,上线前建议删掉或用构建工具移除
  • 右键断点可设“仅当命中 N 次”或“仅当表达式为真”,避免在长循环里反复停住
  • Watch 面板里加 this.stateresponse.data,比每次展开作用域更省力

捕获未处理错误和 Promise 拒绝

页面白屏、接口静默失败,往往不是逻辑错,而是异常没被捕获。控制台里看不到不代表没发生。

VIVA
VIVA

一个免费的AI创意视觉设计平台

下载
  • 监听全局错误:
    window.addEventListener('error', e => console.error('JS Error:', e.error));
  • 捕获未处理 Promise 拒绝:
    window.addEventListener('unhandledrejection', e => console.error('Unhandled Rejection:', e.reason));
  • 注意:这些事件不会触发断点,但能帮你定位哪些地方忘了 .catch()try/catch
  • Vue/React 项目中,这类错误可能被框架吞掉,务必开启 vue.config.jsdevServer.overlay 或 React 的 React.StrictMode 错误边界

console.dir 和 $0 在 DOM 调试中很关键

查元素绑定的事件、数据属性、原型链,console.log 只给快照,console.dir 才是实时可交互的对象树。

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

  • 选中页面元素后,在 Console 里直接输入 $0 就是当前选中节点,$1 是上一个,不用再 document.querySelector
  • console.dir($0) 展开的是 DOM 对象本身(含方法、事件监听器),不是 HTML 字符串
  • getEventListeners($0)(Chrome 特有)能列出该元素所有绑定的事件,包括通过 addEventListener 添加的匿名函数
  • 注意:$0 只在 Elements 面板选中元素后有效;刷新页面后失效,不能存成变量复用
控制台不是万能的,尤其涉及微任务队列、闭包变量生命周期、原型链污染时,单靠输出或断点都容易误判。真正卡住的地方,往往得结合 Performance 面板看调用深度,或者用 chrome://inspect 连接移动端复现。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

1057

2023.08.11

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

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

837

2023.11.06

chrome什么意思
chrome什么意思

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

1057

2023.08.11

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

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

837

2023.11.06

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

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

760

2023.08.03

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

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

221

2023.09.04

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

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

1566

2023.10.24

字符串介绍
字符串介绍

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

649

2023.11.24

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

共42课时 | 9.5万人学习

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

共26课时 | 1.6万人学习

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

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