H5 移动端调试全攻略

随着移动设备的高速发展,H5 开发也成为了 F2E 不可或缺的能力。而移动开发的重中之重就是掌握调试技巧,修 Bug 于无形。php

1、概要

由于移动端操做系统分为 iOS 和 Android 两派,因此本文的调试技巧也会按照不一样的系统来区分。寻找最合适高效的方式,才能让你事半功倍。前端

文章会列举目前适合移动端调试的多种方案,快来选择你的最佳实践吧!node

2、iOS 设备

Safari:iphone 调试利器,查错改样式首选,须要咱们作以下设置:chrome

  • 浏览器设置:Safari - 偏好设置 - 高级 - 勾选「在菜单栏中显示开发」菜单
  • iphone 设置:设置 - Safari - 高级 - 打开 Web 检查器

大功告成,这时候经过手机的 Safari 来打开 H5 页面,咱们经过浏览器开发选项能够看到:npm

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

iOS 模拟器:不须要真机,适合调试 Webview 和 H5 有频繁交互的功能页面。浏览器

首先下载 Xcode ,运行项目,选择模拟器 iphonex,编译后就会打开模拟器,以下:微信

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

能够看到 H5 已经在「壳子」中运行起来了,下来就能够尝试调用 Webview 的方法,和「壳子」交互了。更多的调试技巧能够参考文章:iOS 模拟器调试。网络

具体的调试功能仍是依赖浏览器的开发选项,与上无异,就不赘述了。iphone

3、抓包

Charles:Mac OS 系统首选的抓包工具,适合查看、控制网络请求,分析数据状况。ide

Charles 抓包首先须要配置手机代理,Wifi - 配置代理(IP 地址) - 手动,以下图:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk= watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

配置好手机代理,这时候打开 Charles ,就会收到确认提醒,选择容许。接下来就能够捕获手机的请求了,可是这些都是常规操做,咱们来点高级的。

有意思的是:咱们能够用本地文件来替换线上文件,方便调试,远程定位线上问题。

选择 Structure,找到须要替换的文件,右键菜单 - Map Local,以下图:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

这时候就会打开一个弹窗,填写具体的配置:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

OK,大功告成,快去改动本地文件吧,今后不再怕线上调试了。须要注意的是若是抓取 HTTPS 请求,要安装信任证书,下文会详细说明。

与之相应的是 Windows 平台的 Fiddler,功能大体类似,这里就不细说了。

4、Spy-Debugger

spy-debugger:移动端调试的利器,便捷的远程调试手机页面、抓包工具。

咱们先来安装:

> sudo npm install spy-debugger -g

启动命令:

> spy-debugger

这时候,控制台会打印出以下信息,说明服务已经启动了:

正在启动代理
本机在当前网络下的IP地址为:10.200.24.46
node-mitmproxy启动端口: 9888
浏览器打开 ---> http://127.0.0.1:50389

最后一步,设置手机代理:10.200.24.46,端口号:9888。补充说明一下:

  • Android 设置代理步骤:设置 - WLAN - 长按选中网络 - 修改网络 - 高级 - 代理设置 - 手动
  • iOS 设置代理步骤:设置 - 无线局域网 - 选中网络 - HTTP 代理手动

接下来,尝试一下抓包:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

再打开调试页面:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

HTTPS 抓包,须要安装根证书,下文会详细说明。

5、Whistle

上面推荐了一款操做简单的调试利器,升级一下,看看更增强大的调试工具 whistle

whistle:基于 Node 实现的跨平台 Web 调试代理工具。

whistle(读音[ˈwɪsəl],拼音[wēisǒu])是基于 Node实现的跨平台抓包调试代理工具,有如下基本功能:

  1. 查看 HTTPHTTPS请求响应内容
  2. 查看 WebSocketSocket 收发的帧数据
  3. 设置请求 hosts、上游 http/socks 代理
  4. 修改请求 url 、方法、头部、内容
  5. 修改响应状态码、头部、内容,并支持本地替换
  6. 修改 WebSocket 或 Socket 收发的帧数据
  7. 内置调试移动端页面的 weinre 和 log
  8. 做为 HTTP 代理或反向代理
  9. 支持用 Node 编写插件扩展功能

大体了解后,咱们来尝试安装:

sudo npm install -g whistle

淘宝镜像:npm install whistle -g –registry=https://registry.npm.taobao.org

whistle 安装完成后,执行命令 whistle help 或 w2 help,查看 whistle 的帮助信息:

run       Start a front service
start     Start a background service
stop      Stop current background service
restart   Restart current background service
help      Display help information

这里只列出部分命令,更多请 w2 help 查看。

看到上面的操做,咱们何不试试缩写 w2 start 来启动服务:

w2 start

看到以下的输出,说明服务已经正常启动了:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

这时候在浏览器打开连接,同时手机上配置代理(同 Charles),接下来就能够愉快的调试了。值得注意的是,whistle 的功能远非如此,更多的扩展请移步官网文档,贴张图先预览下:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

记得开启拦截 HTTPS:勾选 Capture HTTPS CONNECTs

6、安装 HTTPS 证书

对于 Charles,按照以下操做安装证书:

help-SSL - Proxying - install Charles root

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

弹出安装证书的提示框:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

按照提示去手机浏览器打开:chls.pro/ssl,安装信任证书便可。

对于 spy-debuggerHTTPS 抓包,须要安装根证书,选择 RootCA,扫描二维码按照提示信任证书。安装证书的时候须要注意如下几件事情:

1.手机必须先设置完代理后再经过(非微信)手机浏览器访问 http://s.xxx (地址二维码)安装证书;
2.手机首次调试须要安装证书,已安装了证书的手机无需重复安装;
3.手机和 PC 保持在同一网络下(好比同时连到一个 WIFI 下);

切记:移动设备和 PC 必须在一个 WIFI 下。

7、真机调试

上面说了不少,可是实际开发过程当中,咱们不会等上线了才去验证兼容性,因此你可能须要提早「真机调试」。这里提供两种方式:

Chrome Remote Devices:依赖 Chrome 来进行远程调试,适合安卓手机。

首先,开启 Android 手机的「开发者选项」,勾选 「USB 调试」。
而后,Chrome 中输入:chrome://inspect,进入调试页面。

很全面的一篇文章,能够参考:Chrome 远程调试。

localhost 转 ip,扫描二维码手机显示,这个比较简单。

能够在浏览器安装一个 Chrome 插件,用于将当前页面连接转换成二维码,这样就能边开发边真机预览,很是方便。

8、调试工具

这里推荐一款调试工具:vConsole,一个轻量、可拓展、针对手机网页的前端开发者调试面板。安装很简单:

npm install vconsole

若是未使用 AMD/CMD 规范,可直接在 HTML 中引入 vConsole 模块。为了便于后续扩展,建议在 <head> 中引入:

<head>
  <script src="path/to/vconsole.min.js"></script>
  <script>
 var vConsole = new VConsole();
  </script>
</head>

若是使用了 AMD/CMD 规范,可在 module 内使用 require() 引入模块:

var VConsole = require('path/to/vconsole.min.js');
var vConsole = new VConsole();

请注意,VConsole 只是 vConsole 的原型,而非一个已实例化的对象。

因此在手动 new 实例化以前,vConsole 不会被插入到网页中。大概功能以下图:

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk= watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=

 

看起来很完美,可是有个小缺点:网络请求,须要刷新页面,但是不少内嵌的 H5 页面是没有机会刷新页面的,因此须要客户端童鞋配合增长刷新的功能方便调试。

9、场景分析

既然移动端调试有这么多种方案,那在实际操做中,我该如何取舍?

说了这么多钟方案,这里总结一下各个方案的适用场景,根据不一样的场景去选择最佳的调试方案,这样才能更快速的输出,Carry 全场:

1.SafariiPhone 调试利器,查错改样式首选;
2.iOS 模拟器:不须要真机,适合调试 Webview 和 H5 有频繁交互的功能页面;
3.CharlesMac OS 系统首选的抓包工具,适合查看、控制网络请求,分析数据状况;
4.Fiddler:适合 Windows 平台,与 Charles 相似,查看、控制网络请求,分析数据状况;
5.Spy-Debugger:移动端调试的利器,便捷的远程调试手机页面、抓包工具;
6.Whistle:基于 Node 实现的跨平台 Web 调试代理工具;
7.Chrome Remote Devices:依赖 Chrome 来进行远程调试,适合安卓手机远程调试静态页;
8.localhost 转 ip:真机调试,适合远程调试静态页面;
9.vConsole:内置于项目,打印移动端日志,查看网络请求以及查看 Cookie 和 Storage

10、白屏处理

移动端的白屏是最头疼的问题,这里顺带提供几种分析问题的思路,以供参考。

1.方案分析 ☆

通常上线后出现问题,咱们最容易想到的就是:是不是新代码引发的问题。因此有效解决手段就是「控制变量法」。

2.代码注释法 ☆

莫名奇妙的白屏,适合页面无异常日志,同时无请求发送,问题集中在单一页面的状况。这种问题比较直观,确定是某一页面出现了代码异常或是无效的 return,致使页面渲染终止,但并不属于异常。这时候,「代码注释法」将是你的最佳选择,逐行去注释能够代码,直到定位问题。关注公众号 逆锋起笔,回复 pdf,下载你须要的各类学习资料。

3.类库异常,兼容问题 ☆

这种场景也会常常遇到,咱们须要用能够调试页面异常的方式,如 SafariSpy-DebuggerWhistlevConsole 查看异常日志,从而迅速定位类库位置,从而找寻替换或是兼容方案。

4.try catch ☆☆

若是你的项目没有异常监控,那么在可疑的代码片断中去 Try Catch 吧。

5.Debug 包 ☆☆☆

在你的项目中装上 [vConsole](https://link.zhihu.com/?target=http%3A//jartto.wang/2018/11/01/mobile-debug/),并配合客户端 debug 插件,360 度无死角监控异常,这才是最有效的方式。

6.ES6 语法兼容 ☆

通常咱们都会经过 Babel 来编译 ES6 ,可是额外的第三方类库若是有不兼容的语法,低版本的移动设备就会异常。因此,先用上文讲述的调试方法,肯定异常,而后去增长 [polyfill](https://link.zhihu.com/?target=https%3A//polyfill.io/v2/docs/examples) 来兼容吧。

 

watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=
相关文章
相关标签/搜索