目前移动端开发还处于一个高速发展的阶段,为了应对快速增加业务需求,移动开发须要更高迭代响应速度,从前期涌现出了以 React Native、Weex 为表明的 web 技术栈,到如今的 flutter 为表明的容器栈,这些跨度开发框架试图提升开发效率的同时,也拥有优秀的运行效率,目前看起来正在接近这个目标。
这些技术,加上 native 开发技术,在不一样应用场景下,咱们能够选择最合适的技术栈,而最古老的跨端技术方案 - Hybrid, 在中小型项目和不复杂的需求中,依然是最合适的选择,目前在网易严选主站,商品详情、促销活动、第三方页面展现仍是用 Hybrid 实现的。 AppHost 提供的就是传统意义上用 web 技术为 native 开发业务功能的能力。css
AppHost 是一套解决 H5 和 native 协做开发的总体框架和服务。试图解决 native 和 H5 目前迭代频繁、时间仓促形成质量不高,业务膨胀后代码混乱,两端联调困难,多端协做彼此割裂等痛点。
做为一种 JSBridge 的实现方法,AppHost 像一座桥,将 native 和 H5 开发打通;
一边是提供设计良好的 native framework 和相关 protocol ,提升 native 接口的交付能力和开发质量;
一边是为 H5 开发的页面和 native 联调,提供辅助调试工具和性能调优工具,让前端开发者对 H5 in App 的调试体验像调试原生浏览器同样,从而提升质量和提高开发效率。前端
这是实际工做中 JSBridge 面对的工做,不少是重复、乏味,又容易出错的。常见场景——“新需求里须要增长新的接口”的流程是这样的:git
AppHost 处理负责 JSBridge 接口从 0 到 N 个、1岁到 5岁、出生到死亡周期,以及 JSBridge 之间的关系管理、对外提供数据支持等工做,因此它是解决方案
,而不是个技术方案(如WebViewJavascriptBridge
只是技术方案)。github
分两部分,AppHost Core 为 native 开发提供基础模块和基本功能封装;AppHost Debug Service 为 native、H5 前端、QA 等人员提供调试服务。下面详细介绍功能。web
对于“native 为 H5 提供接口” 这件事情,如前述,须要多方的协调同步,很容易出现:接口文档过期、文档缺失、接口查找麻烦、接入新 API 不直观、测试不方便,QA 回归不充分,或者是多个环节重复写测试用例等坏状况。
AppHost 的 API 文档模块,将这些环节须要的文档和测试用例,所有集中到开发阶段完成,后续 H5 查询的 API 文档、QA 走查用例、自动化测试,所有自动生成。保证接口文档的最新,省去多个环节的重复建设,内置的自动化测试支持,方便 QA 使用脚本回归测试。shell
电脑浏览器具备访问方便、可展现区域大、输入快捷方便、易于集成第三方调试工具的特色。相同的调试功能,理论上也能够集成在手机 App端,可是体验会大打折扣,是个低效的调试方案。浏览器
在浏览器端 Console ,实现了一个小型命令行程序,指导用户如何使用本 Remote Debugger;同时还提供 即时查询 API 接口 名称、参数解释、示例代码等功能,让你的工做流不须要切换到打开的API 文档文件或者浏览器,保持操做上下文。ruby
Console 里实现了完整 webview 执行环境,将传统语言的探索、调试新特性的体验带到 Remote Debugger,如同 Bash 的 shell prompt
和 ruby 的irb
那样。在这里输入的全部命令如同在远端 webview 的 console 里执行同样。固然还有Off mobile
和On mobile
来切换当前命令是本地执行仍是远端 webview 执行。网络
Console 提供了左侧快捷命令;内置了命令的历史记忆,实现上下箭头遍历;支持 :clear
,清除当前界面等功能框架
咱们知道 Safari Develop 工具是在页面打开后才会出现。若是咱们有个页面由 302 跳转,咱们想抓到想要的请求是作不到的。接入 AppHost 以后,咱们保持Safari Develop 工具打开的状态,在 Remote Debugger 输入命令 ,让当前 webview 加载初始 URL,这样咱们就能够抓到从 302 跳转开始后的网络请求了。
经过:weinre --
命令,不须要改动被调试页面的源码,便可提供 weinre 调试服务,并且一次注入当前 App 启动后全程有效,后续页面无需再注入。用这个特性,甚至能够调试第三方页面。
6.2 **查看严选首页的 onload 事件时间**
6.3 **使用 weinre 调试严选页面**
AppHost 来自做者近年 webview 开发实践总结,真切的感觉到这套设计在面对业务快速发展、技术重构需求、多端协做等方面的优越性,特整理分享出来,不只面向咱们之后的业务开发,也但愿抛砖引玉,和各位同行共享知识,以
在此,但愿 AppHost 能帮你解决在 webview 相关开发过程当中遇到的常见问题,让你更多的时间花在如何完善业务逻辑,加快 App 成长上面,为你的开发工做带来切实的帮助,避免 996,享受工做和生活乐趣。
目前 AppHost 只有 iOS 端。其中 AppHost Core 在网易有钱上使用了 3 年多,支持了网易有钱的不断增加的业务需求,期间解决了不少 WKWebView 遇到的通有的问题。 AppHost Debug Service 目前尚未在线上系统中使用,目前正逐步将 AppHost 总体接入网易严选和网易推手。
详细的技术方案和接入方式见如下连接
但愿各位同行也能分享各自解决方案,共同提升行业 Hybrid 开发体验。