zoukankan      html  css  js  c++  java
  • javascript和web debug技术

    在前端开发中,调试技术是必不可少的技能,本文将介绍五种前端开发必备的调试技术。

    1. Weinre移动调试
    2. DOM 断点
    3. debugger断点
    4. native方法hook
    5. 远程映射本地调试

    Weinre

    在移动上面开发调试是很复杂的,所以就有了weinre。安装weinre可以实现pc来调试手机页面,所以对于移动开发调试是很重要的哦~

    安装weinre

    weinre可以通过npm来安装:

    • 1
    npm install -g weinre
    

    安装完之后,可执行下面的命令来启动:

    • 1
    weinre --httpPort 8080 --boundHost -all-
    

    这样访问自己的127.0.0.1:8080按照提示在需要调试页面中插入一段js,然后就可以调试了。操作界面类似Chrome的 DevTools,具体操作可以看下http://people.apache.org/~pmuellr/weinre/docs/latest/Running.html教程

    原理

    通过在需要调试的页面中引入一段weinre的js,实现pc和手机的socket通信,从而实现实时调试。

    Tips

    1. 如果你嫌每次都要在调试的页面引入js麻烦,可以做个书签或者chrome插件
    2. 如果嫌安装麻烦,可以使用phonegap的weinre:http://debug.phonegap.com/

    DOM断点

    DOM断点是一个Firebug和chrome DevTools提供的功能,当js需要操作打了断点的DOM时,会自动暂停,类似debugger调试。

    使用DOM断点

    1. 选择你要打断点的DOM节点
    2. 右键选择Break on..
    3. 选择断点类型

    Tips

    • Firebug中,DOM断点可以在Script> Breakpoints里面看到
    • chrome DevTools中,需要在Elements面板的DOM Breakpoints中看到

    javascript的debugger语句

    需要调试js的时候,我们可以给需要调试的地方通过debugger打断点,代码执行到断点就会暂定,这时候通过单步调试等方式就可以调试js代码

    使用javascript的断点

    在需要打断点的地方添加debugger

    • 1
    • 2
    • 3
    if (waldo) {
    debugger;
    }
    

    这时候打开console面板,就可以调试了

    Tips

    如果你不知道怎么调试,那么尽快看下:Chrome DevTools中断点部分的教程

    原生代码的hook调试

    因为浏览器自己会内置一些类似window对象这些原生的js方法,当你知道原生代码的确有问题,但是你又不能跟踪调试的时候,你就可以用这个方法了。

    举个例子

    例如我们注意到了一个DOM的属性值发生了变化,但是我们不知道是哪里的代码导致的变化,所以我们可以给DOM元素的setAttribute打个断点,代码如下:

      • 1 var oldFn = Element.prototype.setAttribute;
      • 2  Element.prototype.setAttribute = function (attr, value) {
      • 3   if (value === "the_droids_you_are_looking_for") {
      • 4     debugger;
      • 5     }
      • 6     oldFn.call(this, attr, value);
      • 7   }

    这样,当元素的属性发生了变化的时候,就会执行到断点,你就可以在断点的栈中找出调用的地方来~

    Tips

    这种方法不保证在所有浏览器中有效,比如ios的safari 隐私模式下,我们就不可以修改localStorage方法

    远程映射本地调试

    当线上某个js/css出现问题,我们可以用代理的方式,将远程的文件代理到本地来实现远程映射调试。其实除了这个功能,还可以作为抓包工具,这在移动端是很重要的。推荐Mac用charles Proxyhttp://www.charlesproxy.com/), windows用户使用fiddlerhttp://fiddler2.com/

    这个就不多说了,直接上国内的几篇文章:

    原文阅读(本文没有完全翻译,有所扩展):http://techblog.badoo.com/blog/2013/11/18/5-advanced-javascript-and-web-debugging-techniques-you-should-know-about/

    转载自:http://js8.in/2013/11/20/%E4%BA%94%E4%B8%AA%E4%BD%A0%E5%BF%85%E9%A1%BB%E7%9F%A5%E9%81%93%E7%9A%84javascript%E5%92%8Cweb-debug%E6%8A%80%E6%9C%AF/#more

  • 相关阅读:
    圣诞放长假了
    设计模式Top10排行榜
    成长的烦恼
    小三的故事发家篇
    《家庭财务总管》升级(1.0.0.2)
    紧急项目处理方法
    隐身大法,使民无知
    如何维护自己文章的版权
    在深度学习的视觉VISION领域数据预处理的魔法常数magic constant、黄金数值: mean=[0.485, 0.456, 0.406],std=[0.229, 0.224, 0.225]
    ImageNet数据集下载
  • 原文地址:https://www.cnblogs.com/linsanshu/p/5763115.html
Copyright © 2011-2022 走看看