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

2019-03-02  本文已影响14人  chauI

结论

主流混合开发方案

一开始 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)

WebKit 渲染流程

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


CSSOM

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

Render Tree Virtual DOM diff

Cordova/H5 (Web UI + JSCore)

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

React-Native (Native UI + JSCore)

React-Native

更多可见 Airbnb 的文章

Flutter

Flutter 使用 dart 语言:

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

参考闲鱼在 Flutter 的实践

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

上一篇 下一篇

猜你喜欢

热点阅读