美文网首页
mpvue + iview 项目分包优化

mpvue + iview 项目分包优化

作者: Howie126313 | 来源:发表于2018-07-14 11:49 被阅读0次

    为了增加开发效率,小程序选用了 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 中特有的代码(文档也有写过...当时没理解)


    相关文章

      网友评论

          本文标题:mpvue + iview 项目分包优化

          本文链接:https://www.haomeiwen.com/subject/tcoepftx.html