找回密码
 加入怎通
查看: 714|回复: 1

[其他] 有哪些 JS 调试技巧?

[复制链接]
diyi123yi 发表于 2012-06-06 10:57:08 | 显示全部楼层 |阅读模式
   我大概是从 08、09 年从 Firebug 转入 Chrome Developer Tool,一直用到现在,越用越喜欢。我平时调错时常用的功能有:8 o: A# a0 u; I' d/ d) E
代码格式化
+ E7 Q. y6 e) {2 p) \3 ]  可以将被压缩的代码自动展开0 g# F: U" P+ R0 Y: I; c
实时代码编辑# P) S  j! g4 c/ V% r% q* k% {
  可以在运行时动态改变 JS 代码,并且不需要刷新页面就可以看到效果,一般用这个实时的在代码里插 console.log
2 Y7 v8 s) h4 |  ~DOM 事件/XHR 断点9 }- K' v- f5 U% L1 J- Q
  可以针对 DOM 结构改变/属性改变/键盘鼠标事件 等下断点,直接断到事件的第一个 listener 函数上。还可以对 XHR 请求下断点,断到发起请求的那一行代码上
. K  I2 z2 v) T0 p9 D8 m调用栈分析
, ]+ v2 d* d# }( G& \0 o! @  这个非常常用,Scripts 面板下右上角的那一部分
# H, o1 N9 ]$ z9 x3 Z6 P3 D/ }自动异常断点
6 G# {3 \- l* b8 Y, ~( S  当代码执行出错时,可以自动断到出错的代码行上,直接分析出错时的运行时环境: m; y$ D$ x! W; N& q
分析 HTTP 请求
( Y( `) ^2 g( O5 \  Network 面板下列出了所有的 HTTP 请求,可以很方便的查看请求内容、HTTP 头、请求时间等信息! f. N( @+ w8 q' A
  以线上代码出 Bug 为例。一般上手第一步是使用代码格式化功能将被压缩的线上代码展开,然后开启自动异常断点,尝试重现 Bug。当 Bug 出现时代码会自动断到出错的那一行。然后通过调用栈分析结合控制台找到最开始出错的那个函数上。一般的 Bug 到这里就算找出来了,但是如果这个 Bug 是在事件回调函数或者 XHR 回调函数上,就得结合 DOM 事件断点和 XHR 断点 进一步往上找哪个函数出错。另外,如果是发给服务器请求没有得到正确的 response,可以通过 Network 面板查看请求的参数、Cookie、HTTP 头是否有误。; I2 a$ @4 I( Z  g
  另外,还可以通过 Charles/Nginx/Fiddler 等工具将远程 js 代码映射到自己的电脑上,免去了代码格式化的麻烦,还可以直接编辑。
( p1 W0 U( J4 B& i+ _" S
! I+ k. i' U$ c& O( X. D' q9 a还有些比较小的 Tips:. L" B+ l" Q) X- g' p! T
console.group/console.groupEnd 可以将 log 信息分组展示,看起来更舒服
, @5 Q6 H& E% v) [# c& [console.warn/console.error 可以输出 warning 和 error log( S! q5 ?7 O! N  N: o/ _% z
element 面板右侧实时编辑的 css 样式,可以在 resource 面板里保存起来# v1 |5 X( c6 S  R5 U2 A
关于样式还有个技巧,Elements 面板右上角的 styles 栏,右侧有三个图标,功能依次是:根据当前元素创建一个 css 样式、模拟 :hover/:active 等伪类、颜色值类型选择。实用; L5 h1 J0 R  ^4 N
resource 面板可以删除和修改 cookie/localstorage
2 j( e4 _$ s+ L' cscripts 面板下的 ctrl+o 可以快速跳转脚本文件,ctrl+shift+o 快速跳转函数3 t3 b) x# o; Y+ ?" ~$ A
右下角的齿轮图标里有个选项是开发者工具和网页左右分屏(Dock to the right,默认是上下分屏),宽屏必备2 y8 w2 b# v+ Q: H
接上,还有个选项是禁用 Cookit,必点
" l6 C6 d' r& q8 o接上,在选项面板里还可以手工编辑 user agent 和模拟触摸事件" S7 M9 N/ [8 D& v, i6 \# l) Z
最后说说 IE 6 的调试,我是这么个流程:
3 F7 s9 R, k- Q4 ]( R首先尝试在 Chrome 下重现该 Bug,如果能重现,就先把 Chrome 里能重现的 Bug 修了。确定 Chrome 里 OK,但是 IE 6 有问题,再继续下一步
3 u- S5 Y4 K. x/ {9 j到 IE 里首先尝试高版本 IE,比如 IE 9。E 9 的开发者工具还不错,也可以下断点,调用栈分析、控制台样样都有。如果 IE 9 里没问题,那就继续尝试 IE8,一直定位到能重现该问题的最高版本的 IE 上。即使是 IE 7,其开发者工具也还是勉强能用的……如果不幸的碰上一个 IE 6 only 的 Bug,那就只有继续下一步7 b5 F9 E) I: q' _& A# _( t
到这一步的话一般就是最苦逼的时刻。IE 6 实在是没有太好用的 JS 调试工具(据说 Visual Studio 可以调,我没用过,欢迎补充)。这时候一般就是二分+alert的土法定位到出错行,加上耐心和时间,还有一点点运气。这一步的话强烈推荐开 Fiddler。 + k7 j( y: D' B! D0 V
  ^: X/ {7 P  ^5 k
妇科医院 www.hspayy.com ( |) H+ u* f; }, U
微创男科 www.ljpayy.com $ V4 X( O, F$ |, }- n1 g2 N3 d
装修论坛 www.qcwall.com
回复

使用道具 举报

孤单荒凉 发表于 2026-02-24 04:52:47 | 显示全部楼层
蹲了这么久,终于看到有价值的讨论,支持一下!
回复 支持 反对

使用道具 举报

    您需要登录后才可以回帖 登录 | 加入怎通

    本版积分规则

    QQ|手机版|小黑屋|网站地图|真牛社区 ( 苏ICP备2023040716号-2 )

    GMT+8, 2026-3-25 17:02 , Processed in 0.053267 second(s), 24 queries , Gzip On.

    免责声明:本站信息来自互联网,本站不对其内容真实性负责,如有侵权等情况请联系420897364#qq.com(把#换成@)删除。

    Powered by Discuz! X3.5

    快速回复 返回顶部 返回列表