Vue Router的懒加载路径的解决方法


Posted in Javascript onJune 21, 2018

单页应用产出的入口chunk大小随着业务的复杂度线性增加,导致后期加载速度越来越慢。后面就需要对不同路径下的模块进行拆分,打包到相应的chunk下,按需加载,找到chunk的大小、个数和页面加载速度的平衡点。

解决办法

.vue模块文件按需加载,其实要做到两件事情:一是标记出这是一个异步组件;二是通知webpack把该组件单独产出为一个chunk。

vue的异步组件

官网给出的异步组件写法:异步组件是一个函数,函数的返回值是一个Promise,只是Promise的resolve函数的参数是常规组件的定义本身。

const AsyncCom = () => Promise.resolve({ /* component definition */ })

webpack异步模块的引入办法

这个对webpack不同的版本来说,用法有点区别:

webpack版本在1-2之间,可以使用require.ensure来告诉webpack引入了一个异步模块

require.ensure([AYNC_MODULE_PATH], CALLBACK, CHUNK_NAME)

其实require.ensure编译后是一个叫_webpack_require_.e的函数,其本身是一个thenable实例,require.ensure的回调放到_webpack_require_.e.then(fn)里面
为了满足以上两个条件

const AsyncCom = resolve => require.ensure([], () => resolve(require(AYNC_MODULE_PATH)), CHUNK_NAME);
webpack>=2的版本可以通过import()来指定动态引入的模块
import('./A.vue') // returns a Promise

Vue Router中的懒加载路径的使用办法

// const A = resolve => require.ensure([], () => resolve(require('./a.vue')), 'A');
const A = () => import('./a.vue')
const router = new VueRouter({
 routes: [
  { path: '/a', component: A }
 ]
})

Tips

组合多个异步模块到一个chunk文件

对不同路径进行按需加载,并不一定非得每个路径产出一个chunk,这个还得按不同的业务和场景进行区分,有时候对于同一个业务下的的小异步模块可以进行合并处理。在webapck版本>2.4时,可以在import引入的时候提供一个/* webpackChunkName: CHUNK_NAME*/注释,来表示chunkname,

const A = () => import(/* webpackChunkName: "group-a-b-c" */ './a.vue')
const B = () => import(/* webpackChunkName: "group-a-b-c" */ './b.vue')
const C = () => import(/* webpackChunkName: "group-a-b-c" */ './c.vue')
// webpack.conf.js
output: {
     ......
    // 使用code-split产出的chunk文件名
    chunkFilename: utils.assetsPath('js/[chunkname].[chunkhash].chunk.js'),
    ......
}

总结

以上所述是小编给大家介绍的Vue Router的懒加载路径的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
extjs之去除s.gif的影响
Dec 25 Javascript
网页整体变灰白色(兼容各浏览器)实例
Apr 21 Javascript
jQuery中outerWidth()方法用法实例
Jan 19 Javascript
Javascript实现检测客户端类型代码封包
Dec 03 Javascript
jQuery Ajax 全局调用封装实例代码详解
Jun 02 Javascript
JS验证 只能输入小数点,数字,负数的实现方法
Oct 07 Javascript
Node.js调用fs.renameSync报错(Error: EXDEV, cross-device link not permitted)
Dec 27 Javascript
小程序云开发获取不到数据库记录的解决方法
May 18 Javascript
重学JS之显示强制类型转换详解
Jun 30 Javascript
js常用方法、检查是否有特殊字符串、倒序截取字符串操作完整示例
Jan 26 Javascript
Javascript前端下载后台传来的文件流代码实例
Aug 18 Javascript
react中的DOM操作实现
Jun 30 Javascript
详解如何使用webpack打包JS
Jun 21 #Javascript
vue自定义一个v-model的实现代码
Jun 21 #Javascript
JS实现模糊查询带下拉匹配效果
Jun 21 #Javascript
浅析Vue 生命周期
Jun 21 #Javascript
vue数组对象排序的实现代码
Jun 20 #Javascript
vue项目实现github在线预览功能
Jun 20 #Javascript
node thread.sleep实现示例
Jun 20 #Javascript
You might like
一个php导出oracle库的php代码
2009/04/20 PHP
php输出xml格式字符串(用的这个)
2012/07/12 PHP
CentOS6.5 编译安装lnmp环境
2014/12/21 PHP
PHP cURL初始化和执行方法入门级代码
2015/05/28 PHP
浅谈PHP中其他类型转化为Bool类型
2016/03/28 PHP
PHP封装的XML简单操作类完整实例
2017/11/13 PHP
JQuery slideshow的一个小问题(如何发现及解决过程)
2013/02/06 Javascript
WEB前端设计师常用工具集锦
2014/12/09 Javascript
JavaScript forEach()遍历函数使用及介绍
2015/07/08 Javascript
javascript实现的登陆遮罩效果汇总
2015/11/09 Javascript
jQuery Validate表单验证深入学习
2015/12/18 Javascript
EasyUI创建对话框的两种方式
2016/08/23 Javascript
DropDownList实现可输入可选择(两种版本可选)
2016/12/07 Javascript
jQuery插件版本冲突的处理方法分析
2017/01/16 Javascript
bootstrap配合Masonry插件实现瀑布式布局
2017/01/18 Javascript
React降级配置及Ant Design配置详解
2018/12/27 Javascript
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
vue-router的两种模式的区别
2019/05/30 Javascript
微信小程序实现canvas分享朋友圈海报
2020/06/21 Javascript
vue实现移动端返回顶部
2020/10/12 Javascript
Python中的jquery PyQuery库使用小结
2014/05/13 Python
小小聊天室Python代码实现
2016/08/17 Python
Python socket实现简单聊天室
2018/04/01 Python
pygame游戏之旅 载入小车图片、更新窗口
2018/11/20 Python
Python第三方Window模块文件的几种安装方法
2018/11/22 Python
对django的User模型和四种扩展/重写方法小结
2019/08/17 Python
基于python 凸包问题的解决
2020/04/16 Python
Python urlopen()参数代码示例解析
2020/12/10 Python
详解HTML5中div和section以及article的区别
2015/07/14 HTML / CSS
应征英语教师求职信
2013/11/27 职场文书
公司财务自我评价分享
2013/12/17 职场文书
幼儿园教学随笔感言
2014/02/23 职场文书
工程类专业自荐信范文
2014/03/09 职场文书
股指期货心得体会
2014/09/10 职场文书
高中生旷课检讨书
2014/10/08 职场文书
LeetCode189轮转数组python示例
2022/08/05 Python