为了增加开发效率,小程序选用了 mpvue 作为框架配合 iview 小程序端的 UI 库进行开发。起初是使用 cli 中官方的脚手架进行开发,但是有一些缺点。
首先,目录结构不是特别的方便。每创建一个页面,要在一个文件夹下分别创建 index.vue 和 main.js。然后,官方的脚手架是不支持小程序分包的。所以引入 mpvue-entry 用来统一页面配置到 page.js,同时也让 mpvue 支持了分包。作者整合了一个 mpvue-quickstart 能够直接使用。
以下为相关网址:
mpvue:http://mpvue.com/
mpvue-quickstart:https://github.com/F-loat/mpvue-quickstart
mpvue-entry:https://github.com/F-loat/mpvue-entry
iview:https://weapp.iviewui.com/
mpvue 相关插件汇总:https://github.com/mpvue/awesome-mpvue
Tips:
1.使用 mpvue-entry 后带来的一些配置问题
1)所有页面都集中到 page.js 中进行配置,如果想要配置首页~“首页默认为 pages.js 中的第一项,但会被 main.js 中的配置覆盖(你可以把你的首页写在 main.js 的 pages 的相关配置中)”同时支持新增页面的热更新,省去了重新 start 的步骤。
PS: 写一些东西前还是要好好读读文档,遇到问题先看文档。不要养成张嘴就问的习惯哈(说给自己听)
2)引入后可以很方便的配置这个页面是否需要分包、是否需要编译。
分包的时候需要注意一些问题。tab 相关的页面是必须放在主包中的,分包的目录需要跟 pages 文件夹同级,分包后跳转时尽量使用绝对路径防止相关页面无法找到。如下图,就会生成三个包:pages、packageA 和 packageB。
关于 mpvue 如何实现分包:https://github.com/Meituan-Dianping/mpvue/issues/590
2.关于 iview 的引入
在分包之前因为对项目大小的限制,我只把需要的文件引入到静态文件夹中,然后在个页面的相关配置中引入使用就可以了。(小程序更新后最大支持8M,页面路径最多能够十层)
import Vue from 'vue'
import App from './index'
const app = new Vue(App)
app.$mount()
export default {
config: {
navigationBarTitleText: '编辑标签',
navigationBarTextStyle: 'white',
navigationBarBackgroundColor: '#4F87E4',
usingComponents: {
'i-tag': '/static/iview/tag/index',
'i-toast': '/static/iview/toast/index'
}
}
}
当时为了使用方便把 toast 的方法挂在了 vue 下,但是在设置分包后一下代码出现了问题。
分包前:
const { $Toast } = require('../static/iview/base/index')
Vue.prototype.$Toast = $Toast
分包后:
const { $Toast } = require('../static/iview/base/index.js') // app-only
Vue.prototype.$Toast = $Toast // app-only
以上能够看到在代码后加了一段注释 app-only。用来指定 main.js 中特有的代码(文档也有写过...当时没理解)