mpvue + iview 项目分包优化

2018-07-14  本文已影响0人  Howie126313

为了增加开发效率,小程序选用了 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

mpvue
mpvue-quickstart

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 中特有的代码(文档也有写过...当时没理解)


上一篇下一篇

猜你喜欢

热点阅读