混合开发-选型-技术调研

结论

  • Cordova/Ionic 仅适合小项目或集成简单页面到 apps
  • React Native 天花板较低,对于交互和性能要求较高、需求复杂、需要长期快速迭代的项目优势不大。
  • Flutter 起点比 RN 高,然而不成熟不适合商用。

主流混合开发方案

  • Web UI + JSCore/V8/Other(PWA、Cordova、Ionic)
  • Native UI + JSCore(React-Native、Weex)
  • Native UI + AOT(Flutter)
  • Native UI + WebUI + JSCore (小程序)

一开始 Hybrid 指的是使用 WebView 渲染页面、混合原生页面的开发模式,但是目前 Native UI + JSCore 等方案明显不属于此类,所以口头上经常把纯 Native 以外的都叫做混合开发。

但是 RN 官方并没有标榜为 Hybrid:
Build native mobile apps using JavaScript and React

JSCore

JavaScriptCore is the built-in JavaScript engine for WebKit. It currently implements ​ECMAScript as in ​ECMA-262 specification.
一开始作为 Safari 的浏览器引擎,后来在 iOS 7 作为一个系统级 Framework 提供给开发者,活生生撑起了 RN 和 Weex 等跨平台方案。

浏览器 WebKit

当我们用小程序 IDE/其他模拟器运行 RN/小程序的时候基本都是使用的 PC 浏览器的引擎,和移动端的浏览器引擎很明显是不一样的,所以不要再说什么在模拟器上是没问题这种话了好吗

H5 页面渲染(Web UI)

  • WebView 常见的渲染方式(WebKit):
    HTML + CSS -> DOM Tree + CSSOM -> Render Tree -> Render Layer (Measure) -> GPU 渲染
WebKit 渲染流程

CSS Object Model 是 CSS 样式的映射,在结构上和 DOM 相似,提供了 API 让开发者动态获取和修改 CSS 样式。


CSSOM

Render Tree 描述可见的 DOM 内容,并将 CSSOM 的样式信息关联到节点上。

Render Tree

  • Google 页面渲染和优化的相关文章

  • CSS/JS 的加载和解析都会阻塞页面的渲染

  • JS 直接操作 DOM 会引起 reflow/repaint:
    reflow (回流): 根据 Render Tree 布局(几何属性),意味着元素的内容、结构、位置或尺寸发生了变化,需要重新计算样式和渲染树;
    repaint (重绘): 意味着元素发生的改变只影响了节点的一些样式(背景色,边框颜色,文字颜色等),只需要应用新样式绘制这个元素就可以了;
    reflow 回流的成本开销要高于 repaint 重绘,一个节点的回流往往回导致子节点以及同级节点的回流;

  • React/Vue 用 Virtual DOM 算法去减少重复绘制不必要的 DOM:
    1、用 JavaScript 对象结构表示 DOM 树的结构 (Virtual DOM),然后用根据 Virtual DOM 构建 DOM 树;
    2、当状态变更的时候,重新构造一棵新的 Virtual DOM。对比新旧的 Virtual DOM 树差异;
    3、把(2)的 Virtual DOM 树的差异应用到第一步构建的 DOM 树以触发渲染。
    两个树的完全的 diff 算法是一个时间复杂度为 O(n^3) 的问题。但是在前端当中,你很少会跨越层级地移动DOM元素。所以 Virtual DOM 只会对同一个层级的元素进行对比:

Virtual DOM diff
  • 在具体的开发中,无限列表、路由切换和手势交互方面的问题是比较多的。
    web 端细粒度的手势检测已经不是问题,问题是通过手势检测带来的像素级动画会极大的降低帧率。

Cordova/H5 (Web UI + JSCore)

在内嵌的浏览器中运行界面和逻辑。

  • 实现成本最低;
  • 运行效率最差;
  • 可能存在较多平台兼容问题且无太好解决办法。

React-Native (Native UI + JSCore)

  • 使用 OEM Widgets 渲染出 Native 组件。但是也导致了相对于 React 能实现的布局,RN 仅支持 10%(CSS 子集)。
    在 iOS 上 RN 通过 addSubview() 去渲染 UI,参考文章

  • 将平台兼容问题完全交给 Native 层处理,也就是常说的要写两套代码。

  • JSCore 的通信成为性能的瓶颈,在例如处理滑动回调时毫米级别的高频率的通信将导致性能问题。
    一是因为 Bridge 本身的通信成本问题,这一点 RN 使用 JSContex 避免。
    另一个则是因为 RN 的本身的渲染机制是做了节流的,防止 DOM 变化带来的复杂的高频次渲染。
    (这种频繁通信的需求在传统的 Hybrid 方案中并不常见)

  • 架构上还存在诸如 ListView 长列表的性能问题

React-Native

更多可见 Airbnb 的文章

Flutter

Flutter 使用 dart 语言:

  • 实现了通过 AOT 编译成多个平台的本地代码,避免了 JSCore 通信频次问题;
  • dart 语言的生态小。

并且 Flutter 通过将 Widgets 相关内容移动到程序包中并通过 Canvas 的方式绘制,不再使用平台的 OEM Widgets:

  • 在跨平台的兼容方面较优,可以实现高度自定义而不受平台限制。
  • APK 会相应增大;

参考闲鱼在 Flutter 的实践

  • 性能上,Flutter 页面和 Native 页面体验接近,甚至数据上看在一些低端机上 Flutter 会更流畅,人肉眼已经很难区别。
  • Android 的 Apk 增加 8M,iOS 压缩包增加 16M。
Flutter

资料:
闲鱼掘金文章 & 技术文章
Alibaba 文章及 demo

小程序

基于 Web 且 UI 层与逻辑层分离,业务逻辑都跑在 JavaScript Context 中,UI 在单独的 WebView 上绘制。
可以参考官方人员的架构设计解析

小程序架构

用户在屏幕点击某个按钮,开发者的逻辑层要处理一些事情,然后再通过setData引起界面变化,整个过程需要四次通信。对于一些强交互(例如拖动视频进度条)的场景,这样的处理流程会导致用户的操作很卡。
对于这种强交互的场景,我们引入了原生组件,这样用户和原生组件的交互可以节省两次通信。

原生组件

其他参考文章:
React: The Virtual DOM
Why Flutter doesn’t use OEM widgets
Performance Limitations of React Native and How to Overcome Them
React Native vs Real Native Apps

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容