华为的鸿蒙系统自发布以来,便广受关注。它支持 JavaScript 编写应用的特性,对于前端开发者来说意义非凡。跨端解决方案Rax的团队也于8月份开始与HarmonyOS JS UI框架团队合作,旨在支持使用Rax编写HarmonyOS应用。经过几个月的实践之后,他们决定将内部细节的技术实现带到第十六届 D2 的舞台上与大家分享,让我们人手都能开发一款属于自己的 HarmonyOS 应用。

关于跨端解决方案 Rax

▐  为什么会有跨端

在PC场景中,业务面对的是浏览器,针对性能的操作很有限,同时容器也是固定的。但是,在无线场景中之所以会出现各种端容器有以下三个原因:

  1. 设备&网络差异大带来的性能问题:典型场景比如淘特这种面向下沉用户,会更关注性能问题;

  2. App容器层给了可能性:在无线端可以在容器层做更多定制能力;

  3. 大厂商的超级App生态:尤其在微信结合小程序成功打造自身生态后,更多大流量App也都纷纷基于小程序建设,因此小程序就成为一个必须选择的端。

在以上三方面的背景下,就引发了无线跨端的复杂问题。

▐  跨端背景下需要什么样的技术方案?

跨端背景下的技术方案有2个思路:

  1. 一码多端:开发一套代码可以运行在多个端;

  2. 各写一套:每个端开发一套代码,常见的手机应用就是使用这种方案;

下图中通过研发成本、适配成本、功能一致、招聘成本这四个维度对两种方案进行对比。

  1. 研发成本:一码多端只需要开发一套代码显然成本会低;

  2. 适配成本:由于不同端的适配非常复杂,一码多端的成本就会随之升高;

  3. 功能一致:即业务逻辑的一致性,一码多端由于只有一套代码易于保障功能一致性,各写一套则比较难保障,比如常见的一个功能在Android可以使用但iOS不能;

  4. 招聘成本:一码多端只专注一种代码,相对人员的学习成本也较低。

基于以上对比,大前端或大体量的业务模式基本会选择一码多端的方式。一些有特别需求的场景比如交易场景,由于对稳定性的要求比较高,就会选择各写一套的模式。

▐  社区中一码多端的方案

Rax、Remax、uni-app、Taro等。

▐  Rax是一个怎样的跨端方案?

Rax使用React语法编写Web应用,并且提供上层配套工程框架体系。在跨端能力方面,Rax支持Web、各厂商小程序、Weex等不同端。目前Rax服务手淘内 80% 以上的业务,Rax核心服务于阿里整体无线业务体系。

当 Rax 遇到鸿蒙系统

▐  关于鸿蒙系统

鸿蒙系统是华为自研开发的国产操作系统,整体装机量突破1.5亿。目前鸿蒙系统采用兼容安卓的模式,但在未来,鸿蒙有机会跟安卓、iOS三足鼎立。鸿蒙系统支持使用JavaScript开发系统应用,这是安卓或iOS都很难触达的。

鸿蒙系统的架构分层

▐  鸿蒙系统与跨端的结合

如下表所示,鸿蒙系统上端提供两种应用开发的解决方案:Java和JavaScript。Java开发在未来主要是支持JavaScript的开发。JavaScript提供两种模式:类Web范式和声明式,前者更多会面向大前端生态,而后者更多会面向客户端的开发。鸿蒙系统将JavaScript作为应用开发的一等公民,因此,Rax X鸿蒙具备理论可能性。

▐  业务的诉求

  1. 单独开发一个鸿蒙应用 由于目前鸿蒙系统提供安卓兼容模式,对于业务来说,单独开发一套针对鸿蒙的应用系统成本过高,不具备普适性;

  2. 开发一个有流量入口的服务卡片 服务卡片是鸿蒙系统主推的能力,鸿蒙会分发公域流量给业务使用,有效解决业务层面流量不足的问题,十分符合业务需求。因此,开发一个有流量入口的服务卡片成为阿里以及很多公司的业务场景。

鸿蒙服务卡片示例

▐  技术方案

业务在技术层面的问题,首先是上面提到的单独开发一套应用的成本太高,另外,新技术太多已经学不动了,而使用Rax去开发鸿蒙应用的优势包括:

  1. 使用类React语法开发,不需要学习新的语法;

  2. 一套代码多个端,降低开发成本;

  3. 开发链路上可以更好的结合Web生态;

技术原理:Rax 如何对接鸿蒙应用

Rax对接鸿蒙方案分三部分内容:渲染能力、工程构建和研发链路。

▐  多端渲染

  • VDOM的跨端能力

VDOM的核心特点是标准的数据结构,可以跟具体的端解耦,进而更好的支持跨端渲染;另外,抽象一层标准数据结构能更有机会做到数据驱动UI的编程范式。

  • Rax Driver适配器

在Rax中利用VDOM进行多端渲染的核心是Rax Driver适配器模式。在与端耦合的逻辑中,都会抽象一个Driver,因此会有面向浏览器的driver-dom、面向WEEX的driver-weex,以及小程序中的driver等。

下图中是driver interface的定义,声明与端绑定的方法,然后结合端的能力实现api。

  • Rax Driver生态

在Rax Driver生态中有面向WebView的driver-web,面向Node.js的driver-server,面向小程序的driver-miniapp。右图是一个简单的driver-server的demo,可以看到在server端明确的driver和端解耦。

  • 对接方案

鸿蒙官方提供的类Web开发范式是拆分了三个文件(见下图):index.hml,index.css和index.js,写法与小程序/Vue非常类似。

在这个背景下形成Rax对接鸿蒙系统的三个基本思路:

  1. 语法编译

    逻辑:输入Rax语法,借助Babel工具进行语法编译,最终生成小程序 语法;

    缺点:实现成本高,语法约束多;

  2. 类小程序运行时

    逻辑:用上层Rax框架对接set data进行模板渲染;

    优点:实现周期短;

    缺点:运行时复杂度高,性能劣化;

  3. 对接鸿蒙底层渲染指令

    逻辑:Rax直接对接下层鸿蒙渲染指令创建节点;

    优点:运行时轻量、高性能;

    缺点:实现周期较长,需要对鸿蒙底层进行改造;

  • driver-harmony

下面左图为技术方案设计,最下面两层渲染引擎和JS Framework是鸿蒙提供的核心能力;上面三层是代码层,包含:driver-harmony、Rax Core和业务代码。其中核心部分是driver-harmony对接JS Framework的渲染指令,鸿蒙在JS Framework中提供跟浏览器标准类似的API,在driver中调用API完成节点渲染。下图是一个简单的demo,由于API与浏览器API存在差异,需要一些磨平操作。

在实现driver后就可以实现demo链路的跑通,如下图,左边是鸿蒙页面的一个组件,在这个组件中需要在生命周期onReady里面调用rax render再传入对应的driver-harmony,就可以实现在真机调试上渲染出Rax节点。

▐  工程构建

  • 工程配置

在Rax面向多端的设计中有一个targets,支持web、miniapp等不同的端,当鸿蒙进来后targets只需要加一个harmony,然后再加入一个工程插件来处理鸿蒙应用构建的体系和webpack配置的体系。下图是配置多页面静态结构。

  • 多webpack任务

跨端方案的核心工程问题是构建多个端的代码,多端的构建可能存在差异,webpack的配置也会有所不同,因此在Rax工程体系中引用了多webpack任务的设计。它的执行逻辑是,先加载用户配置读取targets,注册webpack任务后改写webpack配置,最终通过webpack编译生成不同端的产物。

  • Plugin-rax-harmony

在上述基础上,就可以轻松的创建plugin-rax-harmony工程插件。通过这个工程插件可以:

  1. 注册独立的webpack任务为harmony产物的构建;

  2. 定制webpack配置;

  3. 生成鸿蒙产物;

▐  研发链路

  • 方案设计

鸿蒙官方提供了DevEco Studio IDE支持应用的全链路开发调试与打包。

IDE自身已经形成一个闭环,Rax的工程链路如何对接成为核心的问题。

  1. 短期方案 在短期方案中会保留鸿蒙IDE本身提供的能力(下图蓝色框流程),同时重新创建一个Rax项目,生成webpack.dev.server,将Rax产物打包放入鸿蒙src中,src继续IDE链路即可。

  2. 长期方案 支持在DevEco Studio从 Rax 应用创建 -> 开发 -> 调试 -> 发布的全链路研发能力。目前这个方案还在和鸿蒙的团队在讨论之中。

附:Rax与鸿蒙的合作Roadmap

2021年8月:Rax团队和鸿蒙团队第一次会议交流;

2021年10月:结合鸿蒙提供的渲染指令跑通demo;

2021年12月:完成渲染链路的完整对接;与鸿蒙IDE团队沟通全链路方案;

2022年2月:IDE全链路流程开发完成;Rax 相关组件&API适配完成;

2022年3月:结合Harmony 3.0正式发布。

Rax对接鸿蒙的技术方案选择了相对性能优越、运行轻量的长期方案,预计在2022年3月结合鸿蒙Harmony3.0一起正式发布。

团队介绍

飞冰(ICE)团队隶属于淘系前端架构团队,希望能通过研发框架和研发工具改善前端开发者的体验。如果对 icejs、Vite、Webpack、VS Code 插件、Electron 等领域比较感兴趣,欢迎关注我们的 GitHub 仓库:https://github.com/alibaba/ice

✿  拓展阅读

作者|大果

编辑|橙子君

使用跨端解决方案Rax编写鸿蒙应用相关推荐

  1. 跨端物料解决方案-织网

    文末福利:淘系前端团队 618 实践小册 NO.1 背景 随着行业业务发展,需求不断增多,并且各个行业业务各自为政,没有通用化的动力和需求,导致模块无法通用化,复用度低. 小程序成为行业运营趋势,多端 ...

  2. java程序编六角星_跨平台移动端解决方案—Weex

    跨端方案背景 一 1 起因 由于客户端Webview内嵌H5的各种受限,例如性能差.JS执行效率低以及伴随着大量的机型兼容问题,于是有了各种混合跨端开发解决方案:Hybrid.React-Native ...

  3. 滴滴跨端框架 Chameleon 正式支持快应用

    桔妹导读:抗击疫情,桔妹提醒大家出门带好口罩,勤洗手,多通风.武汉加油!中国加油!在大家开工之际,桔妹邀您阅读来滴滴开源专栏内容,为你分享滴滴跨端框架 Chameleon 的最新分享. 0. 目录 点 ...

  4. 聊聊跨端技术的本质与现状

    今日博思: 生命如同寓言,其价值不在与长短,而在与内容. 零.何为跨端 write once, run everywhere 一次编写,四处运行就是跨端的真谛.因为前端当下需要处理的场景实在是太多了: ...

  5. 干货 | 携程机票 App KMM 跨端生产实践

    作者简介 禹昂,携程移动端资深工程师,Kotlin 中文社区核心成员,图书<Kotlin 编程实践>译者. Derek,携程资深研发经理,专注于移动端开发,热衷于各种跨端技术的研究和实践. ...

  6. 重磅!滴滴跨端框架Chameleon 1.0正式发布

    导读:滴滴在 GitHub 上开源的跨端解决方案 Chameleon(简写 CML)正式发布 1.0 版本,中文名卡梅龙:中文意思变色龙,意味着就像变色龙一样能适应不同环境的企业级跨端整体解决方案,具 ...

  7. 重磅!滴滴跨端框架Chameleon 1.0正式发布(学不动啦...)

    原文链接:重磅!滴滴跨端框架Chameleon 1.0正式发布 Chameleon社区 滴滴在 GitHub 上开源的跨端解决方案 Chameleon(简写 CML)正式发布 1.0 版本,中文名卡梅 ...

  8. 初探Flutter跨端游戏开发

    本文作者为奇舞团大前端CodeFarmer 背景 笔者在公司前前后后做了有小一年Flutter 开发,从入门到后面业务方变动,到暂时放弃Flutter.对于Flutter争议不提,我们得承认Flutt ...

  9. 腾讯开源内部跨端框架 Hippy,打磨三年,日均 PV 过亿

    12月20日,腾讯开源跨端框架 Hippy. 在腾讯内部,Hippy 已运行3年之久,跨 BG 共有 18 款线上业务正在使用 Hippy,日均 PV 过亿,且已建立一套完整生态.相较于其他跨端框架, ...

  10. android 开源fc模拟器_星标 4.5K!又一个跨端框架,腾讯开源内部跨端统一开发框架:Hippy...

    点击上方"Github中文社区",关注 看遍Github好玩的项目 大家好,我是Hub哥,每天带你学习(假装了解)一个牛逼,又很碉(沙雕),又不失节操的项目. 今天我在Github ...

最新文章

  1. 解析腾讯行政区划API接口数据
  2. 水稻微生物组时间序列分析2b-散点图拟合
  3. 转.net内存回收与Dispose﹐Close﹐Finalize方法
  4. logback的简单使用
  5. 八十、React中的容器组件和无状态组件
  6. leetcode326. 3的幂 如此6的操作你想到了吗
  7. intent Filter
  8. 好的领导应该是什么脾气
  9. php 漂亮的分页类
  10. 《软件测试》阅读笔记
  11. Mysql远程授权报语法错误
  12. Visual Basic Script 程序参考手册-学习第1天:初步认识VBS,编写第一个Hello World程序,解决中文字符乱码问题,推荐参考书
  13. 如何自动化入侵海康设备
  14. linux安装微信 安装百度网盘 下载大文件
  15. C语言 打印2的n次方
  16. Hbuilder内更改SVN地址(svn服务器IP变更)
  17. Spark SQL原理及常用方法详解(二)
  18. BUU-RSA [RoarCTF2019]babyRSA(威尔逊定理)
  19. access查询mysql_Access数据库 如何创建查询
  20. 如何解决1万个并发连接,用每个客户一个线程的方法

热门文章

  1. s3c2440汇编语言,S3C2440-裸机篇-03 | GPIO的使用(点亮LED、按键检测)
  2. matlab 文本分类,中文文本分类语料库-TanCorpV1.0
  3. APP上传照片后台实现方法
  4. 在linux上使用spi-lcd屏 ST7735
  5. 安装新的package后出现异常错误
  6. 一个人的职业生涯之旅 —— 应届生求职、面试、Offer、跳槽(发展瓶颈、薪资倒挂、职业倦怠、骑驴找马、简历优化)问题分享
  7. 戴尔服务器bios设置u盘启动不了系统,戴尔电脑主板bios设置u盘启动不了怎么办...
  8. 线性代数【8】-1 线性方程组 - 非常重要的概念 - 三个基本的问题
  9. reflector 插件_Reflector Plus Plus-插件,IronPython和其他Peli Goodness
  10. 资源分享 | SAHI:超大图片中对小目标检测的切片辅助超推理库