为了增长开发效率,小程序选用了 mpvue 做为框架配合 iview 小程序端的 UI 库进行开发。起初是使用 cli 中官方的脚手架进行开发,可是有一些缺点。 首先,目录结构不是特别的方便。每建立一个页面,要在一个文件夹下分别建立 index.vue 和 main.js。而后,官方的脚手架是不支持小程序分包的。因此引入 mpvue-entry 用来统一页面配置到 page.js,同时也让 mpvue 支持了分包。做者整合了一个 mpvue-quickstart 可以直接使用。vue
如下为相关网址:git
mpvue:http://mpvue.com/github
mpvue-quickstart:https://github.com/F-loat/mpvue-quickstart小程序
mpvue-entry:https://github.com/F-loat/mpvue-entrybash
iview:https://weapp.iviewui.com/app
mpvue 相关插件汇总:https://github.com/mpvue/awesome-mpvue 框架
##Tips: ###1.使用 mpvue-entry 后带来的一些配置问题 1)全部页面都集中到 page.js 中进行配置,若是想要配置首页~“首页默认为 pages.js 中的第一项,但会被 main.js 中的配置覆盖(你能够把你的首页写在 main.js 的 pages 的相关配置中)”同时支持新增页面的热更新,省去了从新 start 的步骤。 PS: 写一些东西前仍是要好好读读文档,遇到问题先看文档。不要养成张嘴就问的习惯哈(说给本身听)iview
2)引入后能够很方便的配置这个页面是否须要分包、是否须要编译。 分包的时候须要注意一些问题。tab 相关的页面是必须放在主包中的,分包的目录须要跟 pages 文件夹同级,分包后跳转时尽可能使用绝对路径防止相关页面没法找到。以下图,就会生成三个包:pages、packageA 和 packageB。 关于 mpvue 如何实现分包:https://github.com/Meituan-Dianping/mpvue/issues/590 ui
###2.关于 iview 的引入 在分包以前由于对项目大小的限制,我只把须要的文件引入到静态文件夹中,而后在个页面的相关配置中引入使用就能够了。(小程序更新后最大支持8M,页面路径最多可以十层)spa
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 中特有的代码(文档也有写过...当时没理解)