mpx 一款滴滴开源的小程序框架跨平台使用

断了今生、忘了曾经 提交于 2019-12-26 17:16:12

【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>

MPX 框架是滴滴出行推出的一款专注小程序开发的增强型框架。本篇文章将从使用角度谈谈 MPX 的优势与好处。如果嫌内容太长,优势部分每个小节都有简单的一句话总结,可以快速阅读。如果想了解更多设计细节,可以阅读 前一篇文章 - MPX2.0 发布

背景

在小程序逐渐火热的今天,越来越多的开发者需要进行小程序的开发。原生小程序的开发有诸多不便,开发者又需要在众多的小程序框架中做出抉择。

那么今天,我们要给大家安利一款小程序框架:MPX

优势

之所以建议开发者们考虑使用 MPX 框架来开发小程序,是因为 MPX 框架具有一些别的框架所没有的优点。

MPX 立足原生小程序,在保证坑少的同时做了很多能力增强,提供了数据响应、模板增强、性能优化、跨平台开发等能力,以提升用户的开发体验及效率。

接下来会从 原生兼容 -> 第三方组件支持 -> 按需构建 -> 跨平台编译 -> 能力增强 -> 独特性能优势 六个点来逐一讲述。

原生兼容

MPX 完全兼容原生,坑少。渐进接入简单。

从语法风格上,我们可以看到目前市面上流行的小程序框架基本是基于 web 框架(taro/nanachi - react,uniapp/megalo/mpvue - vue)或者是一套全新(chameleon)/ 半全新(wepy)的标准。

使用了这些框架,你所写的代码,并不是小程序代码。而是 react/vue 或者另一套代码。而这些代码源码到小程序代码,需要经过一次全面的转换,这个转换可能会引入一些未知的问题,产生一些坑。

同时随着时间,小程序自身会逐步迭代,做出更多的功能特性,提供更好的组件、方法。而一些框架可能会受限于精力或框架节奏,没有办法第一时间跟进,甚至框架慢慢疏于维护而无法使用。

而 MPX 选择的是,全面拥抱原生

口说无凭,我们来看个典型的 MPX 组件长什么样。

乍一看好像和 vue 没什么区别,也就多了个 json 块,template 里写的是小程序的标签。

由于这一块全是符合微信小程序原生语法,我们是不会做任何转换的,所以你写什么就是什么。(如果使用了 MPX 的增强特性,还是会进行一些必要的转换的,后续我们也会出文章详细解释 MPX 的增强是如何实现的,相对来说,我们的转换比较轻量、透明、易理解)

当微信出了新的能力、新的标签、新的生命周期钩子,使用 MPX 框架来编写的小程序只需要直接用起来就行。

所以,使用 MPX 框架,你可以轻易地使用 自定义组件的 relations 来搞定组件间关系,使用 wxs 来更好地构建页面。

MPX 几乎支持原生的每一个特性,在 .mpx 文件里,模板部分写的是原生小程序的模板语法,脚本部分写的是原生小程序的脚本语法,json 部分写的是原生小程序的配置信息。用 MPX,你才是真的在开发小程序。

目前很多原生小程序开发者可能想尝试下框架,老项目接入框架,选 MPX 肯定是最简单的了。口说无凭,我们搞了个 demo 来给大家打个样:在我们 GitHub 项目中有 examples 文件夹,里面的 原生项目渐进接入 MPX 示例 。

第三方组件库

MPX 提供了完备的第三方组件库支持

上面说了 MPX 对原生的极致兼容,能让你想到什么?对,就是对第三方组件库的完美支持。

支持第三方组件库的重要性大家都知道,所以这个能力大部分框架都支持了。但是支持和完美支持还是有区别的。据简单观察,taro/mpvue/uniapp 对于第三方组件库的支持都是以复制的形式进行的,也就是和微信小程序本来的行为很像。

那么 MPX 是怎么支持第三方组件库的呢,这里有个 demo:也在我们的 GitHub 里的 examples 文件夹下,MPX 使用第三方组件库示例 ,核心代码见下图:

乍一眼看不太出来有什么特别的?没用过别的框架引第三方组件,简单找了找其他框架好像也没提供相应的 demo,用过的朋友可以自行对比下。

在 MPX 里使用第三方组件库,仅需要 *像 web 项目一样 npm 安装即可,并不需要复制文件*。然后在 json 里直接写包名就会去 node_modules 下面查找了。再配合 webpack alias 可以做到更简单、更语义化。

然而这还没有结束~

细心的朋友会发现,这段示例代码中既有 vant 的组件,也有 iview 的组件,如果按照微信的规范,这些组件库会通过 miniprogram 字段指定自己的构建文件生成目录,开发者工具会把这个目录完全拷贝到最终发布的代码里去,我们就会有两个巨大的组件库占据宝贵的空间。

我们当然是希望用多少引多少,而不是一股脑全引进去,对,于是 MPX 提供了按需引用的能力,在下一章按需引用细讲。

以及,组件库目前很少有跨小程序平台的组件库啊,如果我用了 vant,支付宝、QQ 里没有 vant 怎么办?也许这是别的框架不怎么推荐使用第三方库的原因,而 MPX 里,我们帮你把别人的组件库也转了,细节看下下章跨小程序平台

按需引用

通过 webpack 依赖分析收集,使用第三方组件库或者拆分开发大型项目时 MPX 能保证构建的代码全是要用到的代码

原生小程序本身的编译是遍历项目文件夹里所有的 JS,包装成一个 AMD 包,也就是说项目文件夹里所有的文件,不论是否被使用,都会占用包体积并上传。

同时,原生微信小程序的 npm 支持是基于文件夹复制的,第三方包通过声明 miniprogram 字段指定要拷贝的文件夹,不论使用还是未使用的资源(模板 /js/ 样式 / 图片),全会被复制到项目文件夹中。

而我们提供了 @mpxjs/webpack-plugin 插件,借助 webpack 生态,解析.mpx 文件的 json 部分或原生的 json 文件将依赖作为新的入口添加子编译。基于依赖收集,而不是文件遍历。

带来的好处就是:如果你喜欢 vant 的按钮,iview 的输入框,wux 的布局,欢迎尝试 MPX,让你能同时使用多个 UI 框架的同时不用担心应用的体积过大。

同理,面对一个大型项目,我们可以拆成不同的部分,由不同的团队完成后发 npm 包,在一个主项目中引入即可,具体内容可以看文档JSON 增强 - packages一节。

收集依赖的细节可以查阅文档编译构建一节。

跨小程序平台

MPX 的跨平台方法能带着第三方组件库一起跨小程序平台,同时提供了充足完善的条件编译能力。

在 MPX 1.0 时代,MPX 框架是专注提升微信小程序的开发体验,虽然也提供了支付宝版,但代码完全要另写。

而随着越来越多的 super app 提供了小程序能力,目前至少有 5 种体系的小程序(微信、支付宝系列、百度系列、头条系列、QQ),如果每一个平台都需要维护一份代码,工程师人数明显不够用了,所以跨小程序平台的能力也是 MPX 2.0 的主打特性。

我们的跨平台的方法就是转换。都是小程序,语法基本一样,配置、钩子的差异在 MPX 运行时里提供了抹平。

而除此之外最大的区别也就是模板上的标签和指令。所以我们实现了一套转换的架子,再编写一份转换规则,即可完成微信小程序到支付宝、百度、头条小程序的转换。

采用这种转换的模式,非常方便用户理解我们是如何把微信小程序转换成支付宝、百度等小程序平台的。而且只要用户有需求,可以补齐任一套小程序转换其他平台的规则,就可以完成以某个小程序为标准为基础来编写小程序代码以及进一步转换成别的平台的能力。

再结合前面一直在说的我们对原生小程序的支持,就可以撞出一点不一样的东西,比如,前文提到的第三方组件库跨小程序平台。

对,我们能帮你把针对微信编写的 ui 组件库在支付宝、百度上运行起来,带着组件库一起跨小程序平台。

那么一定会有这样一个问题,就算 MPX 对原生的支持再怎么牛逼,有的基础能力只有微信平台有,别的平台没有,MPX 的转换还能无中生有吗?

当然不能,其实这个问题对于所有的跨端框架都是一个问题,所以跨端最核心的问题是,如何搞定差异化部分。

MPX 提供了丰富的条件编译能力,可以以文件为维度差别构建,可以以代码块为维度,也可以以代码维度进行差别构建。

而且 MPX 的差异化构建能力也是完全基于 webpack 实现的,所以上面提到的第三方组件库如果确实存在转换不了的地方,比如 vant 的 picker 组件使用内联 wxs 写了一个小方法叫 isSimple 在模板里调用了,但是这个方法的写法在百度小程序的 filter 脚本(filter 可以理解为百度小程序的 wxs)里不支持,因为百度的 filter 要求必须导出一个对象包裹方法。

最好的解决办法当然是给 vant-weapp 提 pr 帮他们解决一下这个问题,但时间可能会比较慢,所以在 MPX 里,可以利用 webpack 的 alias 能力:

当尝试构建百度小程序时,会优先去查找 pick/index.swan.wxml,再被 alias 到一个 src 下的文件,自己修改一下第三方包里有一些小问题的部分即可。

关于跨平台的条件编译,更多具体信息可以查阅我们的官方文档 - 跨平台条件编译

能力增强

通过数据响应、编译时预处理提供了 computed/watch,完备的样式类型绑定,双向数据绑定,动态组件等一系列方便开发者更好开发小程序的能力增强

能力增强应该是一个框架提供的最核心最重要的能力了,而 MPX 也确实在这里下了很大的力气,提供了多且好用的能力增强,不过受限于此处的篇幅,就只简单介绍,细节大家还是查阅我们的文档的好。

别的框架由于往往基于 react/vue 的,会给个列表写明不支持哪些能力,用户写的时候习惯使然,往往用了后可能才反应过来哦这个不支持。MPX 则是原生的小程序语法写着难受时候突然想起 MPX 有这个能力。

列一下 MPX 增强的能力:

  • 模板上的增强
    • 样式类名绑定
    • 内联事件传参
    • 动态组件
    • 双向绑定
    • 节点获取 ref
  • JS 里的增强
    • 数据响应
    • setData 优化
    • ES6+
  • 样式上的增强
    • 预处理支持
    • rpx 转换
  • JSON 里的增强
    • packages
    • 分包资源优化

MPX 最显著的能力是数据响应,它衍生出 computed/watch,以及双向数据绑定等。这个能力和 Vue 比较像,不同的是在 MPX 里是由 mobx 提供的数据响应能力。

而同样是数据响应,我们做了一些不一样的优化。

性能优势

通过对模板的解析抽象出访问的数据以保证在提供了数据响应能力的同时不至于劣化性能。

mpvue/wepy/megalo 等框架也提供了数据响应的能力,但是数据响应在小程序领域有个较大的问题,微信开发指南里明确提到要注意 setData 的调用频次和数据量的大小。

而数据响应最基本的做法就是数据变了就去 set 数据,这会极大劣化小程序的性能表现。

而 MPX 通过对模板进行解析,抽象出对应的 render 函数,在调用 setData 发送数据前执行 render 函数找到真正需要发送的数据。

效果如图:

小程序开发者工具的 audits 面板能辅助用户分析出可能需要优化的点。正如前文所说,MPX 在红框部分,尤其是红框里的第三条,不将模板上未使用的数据发送到渲染层上做了极大的优化。

只要不出现渲染函数执行失败(会有 warning 在 console 里提示,同时兜底逻辑会进行全量 setData 以保证程序仍可正常运行),使用 MPX 开发的小程序就永远不用担心发送了模板未使用的数据。

虽然只是一个小小的 TODO MVC 示例,但是这个优化和应用的规模没关系,而且同时大家可以尝试别家的小 demo 对比看看。

这个优化的细节可以看前一篇文章,或者我们的文档MPX 运行机制 - 数据响应与性能优化

总结

与目前市面上的诸多框架相比,MPX 希望以原生小程序为基础,全面拥抱原生小程序,在原生小程序的基础上做增强,通过尽可能少的转换实现尽可能多的能力增强,在提升小程序开发体验的同时,保证不因转换或框架的问题产生过多的坑。

MPX 框架的目标用户是对小程序质量有较高要求的开发者,如果你是原生小程序开发者,或者厌倦了解决某些以 web 框架 DSL 语法为基础的转换框架造成的坑,欢迎尝试 MPX 框架。

MPX GitHub 地址:https://github.com/didi/mpx

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!