# 快速开始

# 安装脚手架

npm i -g @mpxjs/cli

# 创建项目安装依赖

在当前目录下创建mpx项目。

mpx create mpx-project

也可以使用npx在不全局安装脚手架情况下创建项目。

npx @mpxjs/cli create mpx-project

执行命令后会弹出一系列问题进行项目初始配置,根据自身需求进行选择,完成后进入项目目录进行依赖安装。

npm install

创建插件项目由于微信限制必须填写插件的AppID,创建普通项目无强制要求。

# 编译构建

使用npm script执行mpx的编译构建,在开发模式下我们执行watch命令,将项目源码构建输出到dist/${平台目录}下,并且监听源码的改动进行重新编译。

npm run serve

# 预览调试

使用小程序开发者工具打开dist下对应平台的目录,对你的小程序进行预览、调试,详情可参考小程序开发指南 (opens new window)

开启小程序开发者工具的watch选项,配合mpx本身的watch,能够得到很好的开发调试体验。

# 开始code

在Mpx中,我们使用@mpxjs/core提供的createApp、createPage和createComponent函数(分别对应原生小程序中的App、Page和Component)来创建App、页面和组件,我们下面根据脚手架创建出的初始项目目录,进行简单的介绍。

进入src/app.mpx,我们可以看到里面的结构和.vue文件非常类似,三个区块分别对应了小程序中的js/wxss/json文件。

js区块中调用createApp用于注册小程序,传入的配置可以参考小程序App构造器 (opens new window),由于app.js是小程序全局最早执行的js模块,一般mpx插件安装等初始化操作也在这里进行。

style区块对应app.wxss定义了全局样式,可以自由使用sass/less/stylus等css预编译语言。

json区块完全支持小程序原生的app.json配置 (opens new window),还额外支持了packages多人合作等增强特性。

<script>
  import mpx, { createApp } from '@mpxjs/core'
  import apiProxy from '@mpxjs/api-proxy'

  mpx.use(apiProxy, {
    usePromise: true
  })
  
  createApp({
    onLaunch () {

    }
  })
</script>

<style lang="stylus">
  .bold
    font-weight bold
</style>

<script type="application/json">
  {
    "pages": [
      "./pages/index"
    ]
  }
</script>

进入src/pages/index.mpx,可以看到同样是.vue风格的单文件结构,比起上面的app.mpx多了一个template区块,用于定义页面模板,除了支持小程序本身的全部模块语法和指令外,mpx还参考vue提供了大量模板增强指令,便于用户更快速高效地进行界面开发。

在js中调用createPage创建页面时,除了支持原本小程序支持的Page配置 (opens new window)外,我们还支持以数据响应为核心的一系列增强能力。

在json中,我们同样支持原生的页面json配置 (opens new window),此外,我们能够直接在usingComponents中填写npm地址引用npm包中的组件,mpx组件和原生小程序组件均可引用,无需调用开发者工具npm编译,且能够通过依赖收集按需进行打包。

为了保障增强能力的完整性,在支持的平台中Mpx优先使用Component构造器创建页面,支持全部Component生命周期;在某些特殊情况下,你可以在@mpxjs/webpack-plugin中传入forceUsePageCtor:true配置来禁用掉这个行为。

<template>
  <list></list>
</template>

<script>
  import { createPage } from '@mpxjs/core'

  createPage({
    onLoad () {
    },
    onReady () {
    }
  })
</script>

<style lang="stylus">

</style>

<script type="application/json">
  {
    "usingComponents": {
      "list": "../components/list"
    }
  }
</script>

最后,我们进入src/components/list.mpx文件,可以看到其构成与页面文件十分相似,对于组件,Mpx提供了和页面完全一致的增强能力

<template>
  <view class="list">
    <view wx:for="{{listData}}" wx:key="index">{{item}}</view>
  </view>
</template>

<script>
  import { createComponent } from '@mpxjs/core'

  createComponent({
    data: {
      listData: ['手机', '电视', '电脑']
    }
  })
</script>

<style lang="stylus">
  .list
    background-color red
</style>

<script type="application/json">
  {
    "component": true
  }
</script>

更多用法可以查看我们的官方实例:https://github.com/didi/mpx/tree/master/examples/ (opens new window)

# 跨平台输出

如果你选择的base平台为微信,mpx提供了强大的跨平台输出能力,能够将你的小程序源码输出到目前业内的全部小程序平台(微信/支付宝/百度/头条/QQ)中和web平台中运行。

执行以下命令进行跨平台输出

npm run build:cross

关于跨平台能力的更多详情请查看这里