Merge pull request #2517 from didi/docs-add-harmony-to-readme docs: 更新鸿蒙支持readme
Merge pull request #2517 from didi/docs-add-harmony-to-readme
docs: 更新鸿蒙支持readme
Mpx, 一款具有优秀开发体验和深度性能优化的增强型跨端框架,支持小程序、Web 与 React Native(iOS / Android / Harmony)输出。
欢迎访问https://mpxjs.cn,跟随我们提供的文档指南使用 Mpx 进行跨端开发。
基于 Mpx 的移动端基础组件库 mpx-cube-ui 已经开源,更多详情查看这里。
Mpx 2.9 版本正式发布,支持原子类、SSR和构建产物体积优化,更多详情查看这里,迁移指南查看这里,相关指南及 API 参考文档已更新。
Mpx 是一款致力于提升开发体验和用户体验的增强型跨端框架,通过 Mpx,我们能够以类 Vue 的开发体验高效优雅地构筑出高性能跨端应用,在所有开放的小程序平台、Web 平台以及 React Native(iOS / Android / Harmony)环境中运行。
mode
wx
ali
swan
qq
tt
jd
web
ios
android
harmony
Harmony(鸿蒙)属于 React Native 输出链路,与 iOS、Android 并列,不是独立的小程序输出形态。
Mpx具有以下功能特性:
# 安装mpx脚手架工具 npm i -g @mpxjs/cli # 初始化项目 mpx create mpx-project # 进入项目目录 cd mpx-project # 安装依赖 npm i # development npm run serve # production npm run build
使用小程序开发者工具打开项目文件夹下 dist 中对应平台的文件夹即可预览效果。
dist
创建项目时选择支持 React Native 的模板后,可按目标平台开发与构建(具体脚本名以脚手架生成为准):
# 开发调试 npm run serve:ios npm run serve:android npm run serve:harmony # 生产构建 npm run build:ios npm run build:android npm run build:harmony
Mpx 负责将业务源码编译为 RN JS bundle 与资源,产物通常输出到 dist/react-native/(或项目内 RN 容器工程的约定目录)。iOS / Android / Harmony 三端共用同一套 Mpx 源码与编译配置,差异通过 mode 与条件编译(.ios.mpx / .android.mpx / .harmony.mpx)处理。
dist/react-native/
.ios.mpx
.android.mpx
.harmony.mpx
Mpx 已支持将同一套基于微信增强语法编写的业务源码输出为 React Native 应用,覆盖 iOS、Android 与 Harmony 三类运行环境。RN 输出会尽量保留 Mpx 原有的开发体验,包括单文件组件、数据响应、组合式 API、条件编译、基础组件、样式编译、路由和 @mpxjs/api-proxy 环境 API 适配等能力。
@mpxjs/api-proxy
需要特别说明的是,Mpx 对 Harmony 的支持属于 React Native 输出链路的一部分:开发者使用 harmony 作为编译目标时,Mpx 负责生成可被 Harmony 侧 React Native / RNOH 工程消费的 JS 与资源产物;原生工程创建、打包、签名和发布仍由对应的 Harmony RN 容器与工具链完成。这意味着 Harmony 不是一套独立的小程序输出形态,而是与 iOS、Android 并列的 RN 运行目标。
在 RN 平台(ios / android / harmony)中,文件维度条件编译也提供兜底逻辑:当 android 或 harmony 目标没有命中对应平台文件时,会自动兜底查找 .ios 文件。因此在多数业务场景下可以先编写一份 RN 通用实现(如 index.ios.mpx),再针对 Android 或 Harmony 的差异补充 .android.mpx / .harmony.mpx 文件。更多内容可查看 RN 快速开始 和 RN 平台文件兜底逻辑。
.ios
index.ios.mpx
<template> <!--动态样式--> <view class="container" wx:style="{{dynamicStyle}}"> <!--数据绑定--> <view class="title">{{title}}</view> <!--计算属性数据绑定--> <view class="title">{{reversedTitle}}</view> <view class="list"> <!--循环渲染,动态类名,事件处理内联传参--> <view wx:for="{{list}}" wx:key="id" class="list-item" wx:class="{{ {active:item.active} }}" bindtap="handleTap(index)"> <view>{{item.content}}</view> <!--循环内部双向数据绑定--> <input type="text" wx:model="{{list[index].content}}"/> </view> </view> <!--自定义组件获取实例,双向绑定,自定义双向绑定属性及事件--> <custom-input wx:ref="ci" wx:model="{{customInfo}}" wx:model-prop="info" wx:model-event="change"/> <!--动态组件,is传入组件名字符串,可使用的组件需要在json中注册,全局注册也生效--> <component is="{{current}}"></component> <!--显示/隐藏dom--> <view class="bottom" wx:show="{{showBottom}}"> <!--模板条件编译,__mpx_mode__为框架注入的环境变量,条件判断为false的模板不会生成到dist--> <view wx:if="{{__mpx_mode__ === 'wx'}}">wx env</view> <view wx:if="{{__mpx_mode__ === 'ali'}}">ali env</view> <!-- RN 输出时 __mpx_mode__ 可取 ios / android / harmony --> <view wx:if="{{__mpx_mode__ === 'harmony'}}">harmony env</view> </view> </view> </template> <script> import { createPage } from '@mpxjs/core' createPage({ data: { // 动态样式和类名也可以使用computed返回 dynamicStyle: { fontSize: '16px', color: 'red' }, title: 'hello world', list: [ { content: '全军出击', id: 0, active: false }, { content: '猥琐发育,别浪', id: 1, active: false } ], customInfo: { title: 'test', content: 'test content' }, current: 'com-a', showBottom: false }, computed: { reversedTitle () { return this.title.split('').reverse().join('') } }, watch: { title: { handler (val, oldVal) { console.log(val, oldVal) }, immediate: true } }, handleTap (index) { // 处理函数直接通过参数获取当前点击的index,清晰简洁. this.list[index].active = !this.list[index].active }, onReady () { setTimeout(() => { // 更新数据,同时关联的计算属性reversedTitle也会更新 this.title = '你好,世界' // 此时动态组件会从com-a切换为com-b this.current = 'com-b' }, 1000) } }) </script> <script type="application/json"> { "usingComponents": { "custom-input": "../components/custom-input", "com-a": "../components/com-a", "com-b": "../components/com-b" } } </script> <style lang="stylus"> .container position absolute width 100% </style>
更多示例请查看官方示例项目
Mpx的核心设计思路为增强,不同于业内大部分小程序框架将web MVVM框架迁移到小程序中运行的做法,Mpx以小程序原生的语法和技术能力为基础,借鉴参考了主流的web技术设计对其进行了扩展与增强,并在此技术上实现了以微信增强语法为base的同构跨平台输出,该设计带来的好处如下:
框架太多坑,不如用原生
核心团队: hiyuki, Blackgan3, anotherso1a, CommanderXL, yandadaFreedom, wangxiaokou, OnlyProbie, pagnkelly, thuman, theniceangel, dolymood
外部贡献者:sky-admin, pkingwa, httpsxiao, lsycxyj, okxiaoliang4, tangminFE, codepan, zqjimlove, xuehebinglan, zhaoyiming0803, ctxrr, JanssenZhang, heiye9, lj0812, SuperHuangXu, twtylkmrh, NineSwordsMonster
微信小程序
| | | | ||| |:—:|:————————————————————————————————-:|:————————————————————————————————-:|:———————————————————————————————————————————————————————-:|:————————————————————————————————-:|:—:|:—:| |滴滴出行|出行广场|滴滴公交|滴滴金融|滴滴外卖|司机招募|小桔加油| || | | | ||| |彗星英语|番薯借阅|疫查查应用| 小桔养车 | 学而思直播课 |小猴启蒙课|科创书店| || | | | ||| |在武院|三股绳Lite|学而思优选课| 食享会 | 青铜安全医生 |青铜安全培训|视穹云机械| || | | | ||| |店有生意通|花小猪打车|橙心优选| 小二押镖 | 顺鑫官方微商城 |嘀嗒出行|汉行通Pro| || | || ||| |交圈|青桔单车|滴滴顺风车|滴滴代驾|新桔代驾|标贝知音||
其他平台小程序:
更多案例,若你也在使用Mpx框架开发小程序,并想分享给大家,请填在此issue中。
提供 微信群 / QQ群 两种交流方式
图片因github网络问题导致不可见的朋友可以点击该链接:https://s.didi.cn/rod
版权所有:中国计算机学会技术支持:开源发展技术委员会 京ICP备13000930号-9 京公网安备 11010802047560号
Mpx, 一款具有优秀开发体验和深度性能优化的增强型跨端框架,支持小程序、Web 与 React Native(iOS / Android / Harmony)输出。
官网及文档
欢迎访问https://mpxjs.cn,跟随我们提供的文档指南使用 Mpx 进行跨端开发。
近期更新
基于 Mpx 的移动端基础组件库 mpx-cube-ui 已经开源,更多详情查看这里。
Mpx 2.9 版本正式发布,支持原子类、SSR和构建产物体积优化,更多详情查看这里,迁移指南查看这里,相关指南及 API 参考文档已更新。
简介
Mpx 是一款致力于提升开发体验和用户体验的增强型跨端框架,通过 Mpx,我们能够以类 Vue 的开发体验高效优雅地构筑出高性能跨端应用,在所有开放的小程序平台、Web 平台以及 React Native(iOS / Android / Harmony)环境中运行。
输出平台支持
mode)wx/ali/swan/qq/tt/jd等webios/android/harmonyMpx具有以下功能特性:
快速开始
使用小程序开发者工具打开项目文件夹下
dist中对应平台的文件夹即可预览效果。React Native 快速开始
创建项目时选择支持 React Native 的模板后,可按目标平台开发与构建(具体脚本名以脚手架生成为准):
Mpx 负责将业务源码编译为 RN JS bundle 与资源,产物通常输出到
dist/react-native/(或项目内 RN 容器工程的约定目录)。iOS / Android / Harmony 三端共用同一套 Mpx 源码与编译配置,差异通过mode与条件编译(.ios.mpx/.android.mpx/.harmony.mpx)处理。跨端输出 React Native
Mpx 已支持将同一套基于微信增强语法编写的业务源码输出为 React Native 应用,覆盖 iOS、Android 与 Harmony 三类运行环境。RN 输出会尽量保留 Mpx 原有的开发体验,包括单文件组件、数据响应、组合式 API、条件编译、基础组件、样式编译、路由和
@mpxjs/api-proxy环境 API 适配等能力。需要特别说明的是,Mpx 对 Harmony 的支持属于 React Native 输出链路的一部分:开发者使用
harmony作为编译目标时,Mpx 负责生成可被 Harmony 侧 React Native / RNOH 工程消费的 JS 与资源产物;原生工程创建、打包、签名和发布仍由对应的 Harmony RN 容器与工具链完成。这意味着 Harmony 不是一套独立的小程序输出形态,而是与 iOS、Android 并列的 RN 运行目标。在 RN 平台(
ios/android/harmony)中,文件维度条件编译也提供兜底逻辑:当android或harmony目标没有命中对应平台文件时,会自动兜底查找.ios文件。因此在多数业务场景下可以先编写一份 RN 通用实现(如index.ios.mpx),再针对 Android 或 Harmony 的差异补充.android.mpx/.harmony.mpx文件。更多内容可查看 RN 快速开始 和 RN 平台文件兜底逻辑。使用示例
更多示例请查看官方示例项目
设计思路
Mpx的核心设计思路为增强,不同于业内大部分小程序框架将web MVVM框架迁移到小程序中运行的做法,Mpx以小程序原生的语法和技术能力为基础,借鉴参考了主流的web技术设计对其进行了扩展与增强,并在此技术上实现了以微信增强语法为base的同构跨平台输出,该设计带来的好处如下:
框架太多坑,不如用原生的顾虑;不管是增强输出还是跨平台输出,最终的dist代码可读性极强,便于调试排查;生态周边
开发团队
核心团队: hiyuki, Blackgan3, anotherso1a, CommanderXL, yandadaFreedom, wangxiaokou, OnlyProbie, pagnkelly, thuman, theniceangel, dolymood
外部贡献者:sky-admin, pkingwa, httpsxiao, lsycxyj, okxiaoliang4, tangminFE, codepan, zqjimlove, xuehebinglan, zhaoyiming0803, ctxrr, JanssenZhang, heiye9, lj0812, SuperHuangXu, twtylkmrh, NineSwordsMonster
成功案例
微信小程序
其他平台小程序:
更多案例,若你也在使用Mpx框架开发小程序,并想分享给大家,请填在此issue中。
交流
提供 微信群 / QQ群 两种交流方式
添加MPX入群小助手等待受邀入群
扫码进入QQ群
图片因github网络问题导致不可见的朋友可以点击该链接:https://s.didi.cn/rod