介绍
跨端容器(Cross-platform container)是一种软件技术,它可以将应用程序在不同的操作系统和/或硬件平台上运行,而无需修改应用程序代码。跨端容器通常提供了一层抽象,使得应用程序可以在不同的平台上运行,而无需了解底层平台的细节。
跨端容器通常使用虚拟化技术来实现平台无关性。例如,Java 虚拟机(JVM)是一种跨平台容器,它可以在不同的操作系统上运行 Java 应用程序。类似地,Docker 是一种跨平台容器,它可以将应用程序和其依赖项打包到容器中,以保证在不同的环境中具有一致的行为。
在移动应用开发中,跨平台容器也被称为跨平台开发框架或混合开发框架。常见的跨端容器包括 React Native、Flutter、Ionic 等。这些框架可以让开发者使用常见的 Web 技术(如 HTML、CSS 和 JavaScript)来构建原生应用程序,并在多个平台上运行,包括 iOS、Android 和 Web 等。
为什么需要跨端
- 开发成本、效率。
- 一致性体验。
- 前端开发生态。
Webview
- Webview,即网页视图,用于加载网页 Url,并展示其内容的控件。
- 可以内嵌在移动端 App 内,实现前端混合开发,大多数混合框架都是基于 Webview 的二次开发;比如 Ionic、Cordova。
- 下面列出了常用的 Webview:
Webview 优势
- 一次开发,处处使用,学习成本低。
- 随时发布,即时更新,不用下载安装包。
- 移动设备性能不断提升,性能有保障。
- 通过 JSBridge 和原生系统交互,实现复杂功能。
Webview 使用原生能力
Javascript 调用 Native:
- API 注入:Native 获取 Javascript 环境上下文,对其挂载的对象或者方法进行拦截
- 使用 Webview URL Scheme 跳转拦截
- IOS 上 window.webkit.messageHandler 直接通信
Native 调用 Javascript:
- 直接通过 Webview 暴露的 API 执行 JS 代码
- IOS webview.stringByEvaluatingJavaScriptFromString
- Android webview.evaluateJavascript
Webview 和 Native 通信
- JS 环境中提供通信的 JSBridge。
- Native 端提供 SDK 响应 JSBridge 发出的调用前端和客户端分别实现对应功能模块。
实现一个简易 JSBridge
小程序
- 微信、支付宝、百度小程序、小米直达号
- 渲染层-Webview
- 双线程,多 Webview 架构
- 数据通信,Native 转发
React Native/WeeX
- 原生组件渲染
- React/Vue框架
- virtual dom
- JSBridge
Lynx
- Vue
- JS Core /V8
- JSBinding
- Native Ul/Skia
Flutter
- wideget
- dart vm
- skia 图形库
通用原理
- UI 组件
- 渲染引擎
- 逻辑控制引擎
- 通信桥梁
- 底层 API 抹平表现差异