在 iOS 12 中,苹果正式弃用 UIWebView,改成 WKWebView,参考官方声明

  后者在性能、稳定性、功能方面有很大提升,并且与 Safari 具有相同的 JavaScript 引擎(JavaScriptCore)。

  从 Android 4.4 开始,增加 Chromium WebView,用来取代 Android WebKit WebView。

  从 Android 5.0 开始,Chromium WebView 支持以 Android System WebView App 的形式在应用商店中下载,可独立升级。

  Android 可以在 App 中集成其他 WebView 组件,例如如 TBS X5 内核的 WebView,或者集成其他 JavaScript 引擎(默认采用 V8 引擎),例如为 React Native 专门优化的 Hermes。

  而 iOS 上就只能使用系统内置的 WebView。由此可知,iOS 和 Android 对于 CSS 和 JavaScript 的支持度各不相同,在研发时需要注意兼容性。

一、调试的困难

  在客户端中调试网页,不像在 PC 的浏览器有那么完善的控制台,对于网页的各方面都能一目了然。

  

1)注入脚本

  若要调试此类页面,需要些方法,比较常见的有在页面中加入 vConsole 脚本,生成一个控制台。

  

  PageSpy 是一款适用于远程 Web 项目调试的工具(可在异地调试),需要在页面注入脚本,并且还需要在服务器中部署一套控制台系统。

  

2)抓包工具

  或者借助 CharlesFiddler 这类抓包工具来查看网络通信、映射本地脚本等。

  

  不过在 Android 6.0 之后,不会信任从抓包工具导出的根证书,这就导致无法在抓包工具中浏览 HTTPS 通信,不过 iOS 没有这方面的限制。

  而网页中的某些业务可能需要借助客户端的能力(JSBridge)才能完成,但这块无法在 PC 浏览器中实现。

  由此可见,需要有种办法能够调试 iOS 和 Android 两种客户端中的网页。

二、iOS

  iOS 的调试比较简单,可以借助 Safari 浏览器实现。

1)显示开发

  首先显示 Safari 浏览器的“开发”菜单。

  以 macOS 为例,偏好设置 > 高级,然后勾选“在菜单栏中显示开发菜单”。

  

2)开启调试

  然后是开启 iPhone 的 Safari 调试模式,设置 > Safari浏览器 > 高级 > 网页检查器 > 启用。

  

3)两端联调

  现在就可以开始调试了,将手机用数据线与电脑连接。

  在访问页面后,选中开发菜单,找到对应的手机,就能看到访问中的网页地址。

  

4)调试窗口

  点击页码地址,进入调试窗口,常规的诸如网络、元素等调试模块都有。

  

  除了能映射客户端 WebView 中的网页之外,Safari 浏览器中的页面也能同步映射到调试窗口。

三、Android

  Android 配置调试的过程比较波折,可以借助 Chrome 浏览器实现。

1)显示开发者选项

  首先需要在手机中显示开发者选项,默认是隐藏的,各款手机的开启过程可能略有不同。

  以小米为例,我的设备 > 全部参数与信息 > MIUI版本,点击 5~8 下,就会有一个开发者模式开启的提示。

  

2)开启 USB 调试

  然后进入更多设置,翻到最后就能看到开发者选项菜单,进入后,开启 USB 调试。

  

3)Chrome Inspect

  接着打开电脑的 Chrome 浏览器,输入 chrome://inspect。

  

  现在可以在客户端中访问网页,下图的 WebView 表示客户端环境,点击 inspect。

  

  应该是弹出控制台,但是却发生了错误,提示 HTTP/1.1 404 Not Found。

  

  这是因为 Android System WebView 的版本低于电脑 Chrome 浏览器的版本,前者是 117,而后者是 120。

  

  如果移动端的 Chrome 浏览器版本较低,那么在调试时,也会出现同样的问题。

  若未出现上述异常,可直接跳过下一节的版本升级。

4)版本升级

  两者的解决办法都是升级,一个是升级 Android System WebView,另一个是升级 Chrome 浏览器。

  而 Android System WebView 需要到 Google Play Store 中更新。

  由于图中已经是最新版本,因此没有显示更新按钮。

  

  在更新成功后,以小米为例,在开发者选项中,选中 WebView 实现,就能看到当前版本。

  

5)调试窗口

  重新访问网页,提示 Remote browser is newer than client browser. Try `inspect fallback` if inspection fails。

  也就是说,客户端的版本高于电脑浏览器,那么可以点击 inspect fallbak 按钮。

  

  在点击后,就能正式出现完整的调试窗口,左边是网页,右边是控制台。

  当有一端移动网页时,另一端也能看到在移动,两者实现了同步。

  

参考资料:

iOS UIWebView与WKWebView 那些事

Web 浏览器相关的一些概念

小米手机开发者选项在哪?

Chrome远程调试

MIUI 更新 WebView 组件

WebView中的页面调试方法的更多相关文章

  1. webview中的页面兼容iphone6和6+

    其实写这篇文章的本不该是我,而应该是开发ios的小伙伴,但作为一个前端,我想我还是有必要做一下记录的! 首先我想说下在iphone6或者6+中webview内嵌套的页面宽度已经不在是320px,而是3 ...

  2. React 环境搭建及页面调试方法

    React 环境搭建及页面调试方法 |作者:RexFang |出处:http://www.cnblogs.com/rexfang/ |关于作者:Java 程序员一枚 |版权:本文版权归作者和博客园共有 ...

  3. ionic 实现 应用内(webview中html页面点击) 和 应用外 (浏览器html页面点击) 打开本地安装应用

    应用内(webview中html页面点击) : 应用内打开本地安装应用指的是webview里打开应用,需要2个步骤: 1: 需要下载一个cordova插件:com.lampa.startapp ,也可 ...

  4. java web 入门级 开发 常用页面调试方法

    这里介绍一下Java web 入门级开发中常用的代码调式方法;  (  仅供入门级童靴 参考) ; 工具: chrome  浏览器 (版本越高越好); Java web 入门级开发 主要就是两个方面: ...

  5. WebView中shouldOverrideUrlLoading和onPageStarted方法的区别

    WebView中的shouldOverrideUrlLoading和onPageStarted这两个方法就是可以捕获到跳转的url,然后进行一系列的操作,但是他们两到底有什么区别呢? 当点击页面中的链 ...

  6. .net的.aspx页面调试方法

    做.net网站开发,有时候需要调试和察看变量, 1.设置好断点以后, 2.设置调试:VS 菜单: 调试————〉附加到进程————〉在 “可用进程” 列表中选择 标题为 "ASP.NET D ...

  7. Webview获取H5页面js方法参数

    #import<JavaScriptCore/JavaScriptCore.h> #pragma mark UIWebViewDelegate - (void)webViewDidFini ...

  8. 在实际项目开发中keil的调试方法

    转载2015-06-14 20:23:04 一.在keilc的调试状态下,如何观察各个片内外设的运行状态?如何修改它们的设置?​ 在调试状态下,点击Peripherals菜单下的不同外设选项命令,就会 ...

  9. mobile web页面调试方法

    此文已由作者张含会授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 开发过程问题排查 Chrome Emulation关键词:使用方便 模拟各种设备尺寸.像素比.自定义user ...

  10. vscode中php断点调试方法!

    一.PHP的代码断点调试 1.打开vscode的首选项设置,添加"php.validate.executablePath": "D:\\newXampp\\php\\ph ...

随机推荐

  1. 全网最详细Java-JVM

    Java-JVM ①JVM概述 ❶基本介绍 JVM:全称 Java Virtual Machine,一个虚拟计算机,Java 程序的运行环境(Java二进制字节码的运行环境) 特点: Java 虚拟机 ...

  2. Cplex求解教程(基于OPL语言,可作为大规模运算输入参考)

    最近导导让牛牛改篇论文,牛牛在她的指导下把非线性问题化成了线性.然鹅,化成线性后的模型决策变量和约束条件均达到上百甚至上千个,这让牛牛犯了难,以下方法或许能为这样大规模模型的变量和约束输入提供思路(๑ ...

  3. 给网站添加xml地图索引写法和应用

    使用php给网站添加xml地图索引写法 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 ...

  4. Go 多版本管理工具

    Go 多版本管理工具 目录 Go 多版本管理工具 一.go get 命令 1.1 使用方法: 二.Goenv 三.GVM (Go Version Manager) 四.voidint/g 4.1 安装 ...

  5. 下载、安装CAN-EYE植被参数工具

      本文介绍植被指数计算软件CAN-EYE的下载.安装方法.   CAN-EYE软件是由法国国家农业研究院(French National Institute of Agricultural Rese ...

  6. 【Unity3D】Cesium加载大地图

    1 前言 ​ Cesium 是一个地球可视化平台和工具链,具有数据切片.数据分发.三维可视等功能. ​ Cesium 支持 JS.Unity.Unreal.O3DE.Omniverse 等平台,框架如 ...

  7. Pandas 读取 Excel 斜着读

    读取 Excel 斜着读数据 import pandas as pd def read_sideling(direction, sheet_name, row_start, col_start, ga ...

  8. 栈溢出-GOT表劫持测试

    1.目标程序源代码 char name[64]; int main(){ int unsigned long long addr; setvbuf(stdin,0,2,0); setvbuf(stdo ...

  9. 配置nginx访问控制-设置防盗链

    1.设置访问控制.只允许本机查看nginx的status状态信息,其它人均拒绝: nginx -V查看nginx是否有status模块,如果没有需要添加 编辑修改nginx.conf文件:在serve ...

  10. 一文读懂强化学习:RL全面解析与Pytorch实战

    在本篇文章中,我们全面而深入地探讨了强化学习(Reinforcement Learning)的基础概念.主流算法和实战步骤.从马尔可夫决策过程(MDP)到高级算法如PPO,文章旨在为读者提供一套全面的 ...