作者 | MorJS 技术团队

出品 | 阿里巴巴终端技术

Mor (发音为 /mɔːr/,类似 more) 是饿了么开发的一款基于小程序 DSL 的,可扩展的多端研发框架。

使用 MorJS,我们只需书写一套(微信或支付宝)小程序,就可以通过 MorJS 的转端编译能力,将源码分别编译出可以发布在不同端(微信/支付宝/百度/字节/钉钉/快手/QQ/淘宝/H5)的产物。MorJS 还支持小程序、小程序插件、小程序分包之间的形态转换,同时也配备了从源码到构建产物全阶段的插件体系,满足各类功能扩展,提升开发体验和开发效率。

以下是饿了么-美食外卖频道在微信、支付宝、抖音小程序及 H5 中的表现:

为什么要做 MorJS?

目前各大平台都相继推出了自己的小程序,饿了么 C 端业务需要在不同平台小程序进行投放,这些项目大多是以支付宝或微信原生 DSL 编写,面对业务渠道的不断增加,我们尝试了多种方法来兼容多端适配,但由于不同平台间小程序代码写法、能力支持的差异性逐步变大,过去的方案无法满足新业务的需求,我们需要一套跨端研发框架能解决以下诉求:

▶ 原生 DSL 支持,方便现有小程序 DSL 编写的存量业务使用;

▶ 降低性能开销,尽可能轻运行时,减少编译构建的时长;

▶ 便捷的使用,一键转换为支持各小程序平台使用的产物;

▶ 拓展的功能,提供针对大型复杂小程序的解耦方案;

▶ 灵活的配置,能够简单的增加修改多套不同端的项目配置;

▶ 产物优化能力,压缩构建产物体积,减少小程序包大小;

在明确这几点后,我们调研了业界所有主流技术框架,发现并没有能完全满足我们需求的方案,所以我们决定自研 MorJS。

如何使用?

MorJS 是基于小程序原生 DSL 进行扩展的,只要你掌握微信或支付宝任意一种小程序,那你就几乎掌握了 MorJS。

MorJS 提供了官方脚手架工具用于创建新项目,同时也支持已有小程序引入相关依赖接入 MorJS。

开始一个新项目

▶ MorJS 项目示例:https://github.com/eleme/morjs/tree/main/examples

1.创建项目,选定项目目录,在目录终端执行以下任一命令:

$ npm init mor # npm 创建项目
$ yarn create mor # yarn 创建项目
$ pnpm create mor # pnpm 创建项目

2.选择对应的工程类型,按照提示完成初始化操作

✔ 请选择工程类型 › 小程序
✔ 请选择源码类型 › 微信小程序 DSL
✔ 是否使用 Typescript … 否 / 是
✔ 请选择 CSS 预处理器 › less
✔ 请输入 小程序 的名称 … myapp
✔ 请输入 小程序 的描述 … my first app
✔ 用户名 … yourUserName
✔ 邮箱 … your@gmail.com
✔ 请输入 Git 仓库地址 … https://github.com/yourUserName/myapp
✔ 请选择 npm 客户端 › npm / pnpm / yarn
…

3.执行编译命令启动项目:

$ npm run dev

4.多端产物已构建在_ dist_ 目录下,分别用对应平台的 IDE 打开即可开发预览

已有小程序项目接入

1.在已有项目中添加必要的依赖:

$ npm i @morjs/cli -D && npm i @morjs/core --save

2.在项目根目录下增加配置文件_ mor.config.ts_

import { defineConfig } from '@morjs/cli'export default defineConfig([// 第一套配置: 微信 DSL 编译{name: 'wx',sourceType: 'wechat', // 源码类型: 微信 DSLtarget: 'wechat', // 编译目标: 微信compileMode: 'bundle', // 编译模式: 打包模式},// 第二套配置: 微信转支付宝{name: 'ali',sourceType: 'wechat', // 源码类型: 微信 DSLtarget: 'alipay', // 编译目标: 支付宝compileMode: 'bundle', // 编译模式: 打包模式},// 第三套配置: 微信转 Web{name: 'web',sourceType: 'wechat', // 源码类型: 微信 DSLtarget: 'web', // 编译目标: WebcompileMode: 'bundle', // 编译模式: 打包模式}
])

3.在_ package.json_ 中配置脚本:

{"scripts": {
+   "dev": "mor compile -w",
+   "build": "mor compile --production"}
}

4.在项目目录终端下执行编译命令启动项目:

$ npm run dev

5.多端产物已构建在_ dist _目录下,分别用对应平台的 IDE 打开即可开发预览。

MorJS 核心能力

多端编译:提供一码多端转换能力

从诞生之初,MorJS 的一个核心能力就是实现小程序一码多端的转换,让一套代码经过编译后对应的各端产物,分别在多个小程序平台上运行,让开发成本,招聘、管理、测试各方面成本都大幅下降。截止到目前,我们已经支持多数小程序平台的转换。

如果你对多端编译的实现感兴趣,可参见文档《MorJS 如何工作》:https://mor.eleme.io/guides/introduction/how-mor-works。

集成研发:提供复杂小程序解耦开发能力

随着业务需求的不断增加,很多小程序项目不可避免的会出现体积巨大化的问题。虽然小程序官方提供了小程序分包、小程序插件的解决方案,但基于同一个小程序代码库,众多分包、插件的迭代情况复杂,实际业务难以解耦。如果你的项目遇到类似的问题,可以使用 MorJS 提供的集成研发能力,把各个分包、插件、模块分成一个个独立的项目,并通过集成研发将小程序宿主和这些子模块通过拉包、编译、构建、合并等一系列处理,合并为一个完整小程序进行开发、调试和部署。

如果你对集成研发的实现感兴趣,可参见文档《复杂小程序集成》:https://mor.eleme.io/guides/advance/complex-miniprogram-integration。

形态互转:提供小程序多形态转换能力

随着投放场景的增加,不同业务在不同小程序端的形态可能并不相同。例如一个在支付宝端的小程序应用,在某些场景下希望他以分包的形式接入到微信小程序中。于是让项目在独立小程序、小程序插件、小程序分包应用形态间互相转换成为一个难题。

MorJS 提供的形态一体化能力,可以在尽量减少业务代码修改的前提下,提供同一个项目在以不同端(微信、支付宝、淘宝、抖音等)不同形态(小程序、小程序插件、小程序分包)间的转换能力。

如果你对形态一体化的实现感兴趣,可参见文档《小程序形态一体化》:https://mor.eleme.io/guides/advance/unity-of-forms。

H5 同构:提供小程序 DSL 转 H5 能力

除了多端多形态的小程序外,不少开发者还面临着 H5 场景的投放。对此, MorJS 提供将小程序项目转换为 Web 项目的能力。这一能力的核心是将小程序转换成一个基于 **React **的项目产物。无论是整个工程项目的转码、或是单个组件的编译,MorJS 都能够支持。

如果你对转 Web 开发的实现感兴趣,可参见文档《MorJS Web 开发》:https://mor.eleme.io/web/basic/quickstart

其他

除此上述核心能力外,MorJS 围绕小程序实现了一系列研发生态能力的建设,包括但不限于以下:

▶ 条件编译:提供对于多端或不同环境构建产出不同代码的能力,更加灵活的解决不同场景的适配问题;

▶ 产物压缩:提供了不同类型文件的最小化兼容压缩方式,并保留配置选项对高级压缩方案的扩展支持;

▶ Mock 能力:提供小程序本地 JSAPI mock 能力,解决开发阶段无法联调接口请求数据的痛点;

优势与现状

MorJS 的优势

如你所见,MorJS 是一套基于小程序 DSL (支付宝或微信) 的框架。他的易用性、标准化和灵活性,使得开发者能更好地专注于业务,降低研发、调试成本,提高开发者的工作效率。

使用现状

截止目前,MorJS 支持 4 种编译形态(小程序、小程序插件、小程序分包、H5),支撑了饿了么 C 端大多数业务在各个渠道上的研发和投放。通过 MorJS 的开源,我们期望能把其中的技术细节、架构设计和技术思考呈现给大家,为有类似多端同构需求的企业和开发者服务。

MorJS 为饿了么解决了大量业务在多端研发上的差异问题,让小程序开发的重心回到产品业务本身,减少使用者对多端差异兼容的投入,在通过开源让大家更好地了解和使用这项技术的同时,我们也希望能够借此吸引到更多志趣相投的小伙伴参与共建,一起加速小程序一码多端能力的发展。欢迎广大小程序开发者们与我们交流。以上是对 MorJS 的简单介绍,如果想要详细了解可通过下述方式:

▶ GitHub:https://github.com/eleme/morjs

▶ 官网地址:https://mor.eleme.io/

☞ChatGPT 将冲击数据库!中国数据库开发者报告正式发布
☞乐视回应四天半工作制:体感非常好;OpenAI CEO 否认在训练 GPT-5;iOS 17 或增加更多灵动岛功能|极客头条
☞裁掉6000人后,马斯克:管理Twitter的心情就像过山车,现金流转正!

一码跑遍众多小程序,饿了么开源自研多端框架 MorJS相关推荐

  1. 2021外卖返利小程序饿了么美团外卖侠分销系统源码

    外卖CPS红包小程序源码分享 外卖返利小程序饿了么美团吃喝玩乐电影票对接公众号返利系统分销系统源码 [小程序]外卖CPS优惠券小程序平台v3.0源码 外卖红包小程序 美团外卖小程序 饿了么外卖小程序 ...

  2. 外卖返利小程序饿了么美团吃喝玩乐电影票对接公众号返利系统分销系统源码

    外卖返利cps分销系统每日领卷美团优惠券红包流量小程序搭建源码 外卖红包小程序 美团外卖小程序 饿了么外卖小程序 美团饿了吗红包,先领红包再下单.外卖红包,cps分成,别人领红包下单,你拿佣金. 美团 ...

  3. 扫码点餐小程序源码_扫码点餐小程序有什么用?怎么制作?

    现在小程序扫码点餐服务已经越来越普及,当用户需要点餐时,无需麻烦服务人员,只需扫描餐桌上或者海报上的小程序码,就能快速点餐下单.这样不仅节约了排队时间,也提高了商家自己的服务效率. 上线了小程序案例, ...

  4. 医疗小程序源码_零售小程序源码,零售小程序商城

    零售小程序开发(贺经理:188微1924电2925同号),零售小程序定制,零售小程序源码,零售小程序商城,零售商城小程序,零售小程序平台,零售小程序软件,开发零售小程序,近年来,实体经济转型.商流量红 ...

  5. 微信扫码点餐小程序怎么做,一步步教你

    在当今数字化时代,更多的餐厅开始使用扫码点餐系统.这种系统可以提高顾客的点餐效率,减少服务员的工作负担.如果你也想要在你的餐厅中使用扫码点餐系统,那么你来对地方了. 第一步:搭建微信小程序后台 在微信 ...

  6. 微信小程序实现微信APP上的扫一扫扫码跳到小程序对应的结果页面和签字等功能

    最近做了一个小程序项目,这个小程序是搭配APP端使用的,大概需求是这样的,用户用微信的扫一扫或小程序首页的扫一扫都可以实现对APP上的二维码进行扫码识别,识别成功之后跳到页面进行渲染,然后用户可以对其 ...

  7. 微信读书登陆界面java_(JAVA后端)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好...

    转载地址:(JAVA后端)微信小程序-毕设级项目搭建-微信阅读小程序(内含源码,微信小程序+java逻辑后台+vue管理系统)~不求完美,实现就好 转载请注明出处 一.环境搭建 相关环境软件:JDK1 ...

  8. 扫描二维码打开微信小程序,携带参数,含配置和代码详解

    今天有个新需求,需要用户扫码打开我们小程序,需要携带信息记录邀请人是谁. 废话不多说,我们进入主题,首先要到小程序里面做配置.在开发管理里面,找到开发配置,往下滑到扫普通链接二维码打开小程序配置项里, ...

  9. [含文档+源码等]微信小程序校园生活小助手+后台管理系统前后分离VUE[包运行成功]

            博主介绍:✌在职Java研发工程师.专注于程序设计.源码分享.技术交流.专注于Java技术领域和毕业设计✌ 项目名称 [含文档+源码等]微信小程序校园生活小助手+后台管理系统前后分离V ...

最新文章

  1. 利用Python进行数据分析 Note 1
  2. win10禁止dpi缩放在哪_Win10最新DPI缩放技术怎么设置?
  3. 1027. Colors in Mars
  4. Gigabit Ethernet复制数据会异常的缓慢
  5. Myeclipse编辑器简单使用整理
  6. PP-YOLO是最先进的吗?
  7. javascript 函数的几种声明函数以及应用环境
  8. C语言实现任意两种进制之间互相转换
  9. cacti气象图设置
  10. 《网上订餐系统》开发全程回忆
  11. python一阶差分_如何用Python对数据进行差分
  12. 店宝宝:拼多多上线新业务 对标微信小商店
  13. MDT 2013 从入门到精通之WDS、MDT工作台配置
  14. JavaScript中常用数组方法总结
  15. html判断手机浏览器,JS判断浏览器iOS(iPhone)、Android手机移动端
  16. MLAPI的升级之路
  17. java piggy,PiggyMetrics windows 部署
  18. Android 8.1 Audio框架(二)AudioPolicy路由策略实例分析
  19. 国外变电站3d可视化技术发展_国外沥青路面纵向施工接缝技术的发展
  20. 利用PuTTY配置端口映射,实现外网对服务器的访问

热门文章

  1. 2018教育培训行业研究报告
  2. Android流畅启动动画,简单设置你的安卓 绝对流畅到爆
  3. 从二本到ICLR杰出论文奖,我用了20年
  4. 大数据分析-零基础学Tableau+超详细讲解+示例练习(二)
  5. 亲测可用|亚信防毒墙网络版卸载图文教程
  6. 支持Mac 基于SymbianOS的XCode插件发布
  7. Week Of Code 28
  8. 解读BLM业务设计中的战略控制点
  9. 通过GRUB引导安装Red Flag系统
  10. 下载Android 源码(高墙之下,只能用镜像啦)