Vue代码分割懒加载的实现方法


Posted in Javascript onNovember 23, 2017

什么是懒加载

懒加载也叫延迟加载,即在需要的时候进行加载,随用随载。

为什么需要懒加载

在单页应用中,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,延时过长,不利于用户体验,而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时

如何与webpack配合实现组件懒加载

1、在webpack配置文件中的output路径配置chunkFilename属性

output: {
path: resolve(__dirname, 'dist'),
filename: options.dev ? '[name].js' : '[name].js?[chunkhash]',
chunkFilename: 'chunk[id].js?[chunkhash]',
publicPath: options.dev ? '/assets/' : publicPath
},

chunkFilename路径将会作为组件懒加载的路径

2、配合webpack支持的异步加载方法

  • resolve => require([URL], resolve), 支持性好
  • () => system.import(URL) , webpack2官网上已经声明将逐渐废除, 不推荐使用
  • () => import(URL), webpack2官网推荐使用, 属于es7范畴, 需要配合babel的syntax-dynamic-import插件使用, 具体使用方法如下
npm install --save-dev babel-core babel-loader babel-plugin-syntax-dynamic-import babel-preset-es2015
use: [{
loader: 'babel-loader',
options: {
presets: [['es2015', {modules: false}]],
plugins: ['syntax-dynamic-import']
}
}]

引言

而在webpack > 2的时代,vue做代码分割懒加载更加的easy,不需要loader,不需要require.ensure。

import解决一切。

分割层级

Vue代码分割懒加载包含如下几个层级:

      1、 组件层级分割懒加载

      2、 router路由层级

      3、 Vuex 模块

组件层级代码分割

//全局组件
Vue.component('AsyncComponent', () => import('./AsyncComponent'))

//局部注册组件
new Vue({
 // ...
 components: {
 'AsyncComponent': () => import('./AsyncComponent')
 }
})

// 如果不是default导出的模块
new Vue({
 // ...
 components: {
 'AsyncComponent': () => import('./AsyncComponent').then({ AsyncComponent }) => AsyncComponent
 }
})

路由层级代码分割

const AsyncComponent= () => import('./AsyncComponent')

new VueRouter({
 routes: [
 { path: '/test', component: AsyncComponent}
 ]
})

Vuex 模块代码分割,vuex中有动态注册模块方法,同时也是加上import

const store = new Vuex.Store()

import('./store/test').then(testModule => {
 store.registerModule('test', testModule)
})

总结

在一般项目中,我们按照router和components层面分割(或者只使用router分割)就足够了。大型项目可能三者都会用到,但用法都很简单,不是么?

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
网页常用特效代码整理
Jun 23 Javascript
Javascript 个人笔记(没有整理,很乱)
Jul 07 Javascript
在JavaScript中获取请求的URL参数
Dec 22 Javascript
jquery下jstree简单应用 - v1.0
Apr 14 Javascript
JavaScript中的Math.atan2()方法使用详解
Jun 15 Javascript
理解javascript闭包
Dec 15 Javascript
微信小程序 框架详解及实例应用
Sep 26 Javascript
AngularJS使用angular.bootstrap完成模块手动加载的方法分析
Jan 19 Javascript
JavaScript数据结构中串的表示与应用实例
Apr 12 Javascript
jqgrid实现简单的单行编辑功能
Sep 30 Javascript
node.js实现简单的压缩/解压缩功能示例
Nov 05 Javascript
vue相关配置文件详解及多环境配置详细步骤
May 19 Javascript
初探js和简单隐藏效果的实例
Nov 23 #Javascript
详解如何在angular2中获取节点
Nov 23 #Javascript
Vuejs中使用markdown服务器端渲染的示例
Nov 22 #Javascript
浅谈Vue-cli 命令行工具分析
Nov 22 #Javascript
JavaScript数据结构与算法之队列原理与用法实例详解
Nov 22 #Javascript
深入理解Vue官方文档梳理之全局API
Nov 22 #Javascript
初识 Vue.js 中的 *.Vue文件
Nov 22 #Javascript
You might like
PHP关联数组的10个操作技巧
2013/01/21 PHP
php采用ajax数据提交post与post常见方法总结
2014/11/10 PHP
PHP使用pdo实现事务处理操作示例
2018/09/05 PHP
短信提示使用 特效
2007/01/19 Javascript
使用js判断控件是否获得焦点
2014/01/03 Javascript
通过pjax实现无刷新翻页(兼容新版jquery)
2014/01/31 Javascript
javascript如何创建对象
2016/08/29 Javascript
js实现的在线调色板功能完整实例
2016/12/21 Javascript
JS中IP地址与整数相互转换的实现代码
2017/04/10 Javascript
jQuery自动或手动图片切换效果
2017/10/11 jQuery
使用express+multer实现node中的图片上传功能
2018/02/02 Javascript
详解自定义ajax支持跨域组件封装
2018/02/08 Javascript
JSONP原理及应用实例详解
2018/09/13 Javascript
关于React动态加载路由处理的相关问题
2019/01/07 Javascript
vue实现微信二次分享以及自定义分享的示例
2019/03/20 Javascript
json解析大全 双引号、键值对不在一起的情况
2019/12/06 Javascript
详解Typescript 内置的模块导入兼容方式
2020/05/31 Javascript
微信小程序学习总结(五)常见问题实例小结
2020/06/04 Javascript
[04:00]黄浦江畔,再会英雄——完美世界DOTA2 TI9应援视频
2019/07/31 DOTA
Mac OS X10.9安装的Python2.7升级Python3.3步骤详解
2013/12/04 Python
Python 爬虫爬取指定博客的所有文章
2016/02/17 Python
python实现外卖信息管理系统
2018/01/11 Python
使用selenium模拟登录解决滑块验证问题的实现
2019/05/10 Python
Windows系统Python直接调用C++ DLL的方法
2019/08/01 Python
TensorFlow实现指数衰减学习率的方法
2020/02/05 Python
CSS的background属性及CSS3的背景图片设置总结
2016/06/13 HTML / CSS
JVM是一个编译程序还是解释程序
2012/09/11 面试题
小学美术教学反思
2014/02/01 职场文书
质量承诺书怎么写
2014/05/24 职场文书
招商引资工作汇报材料
2014/10/28 职场文书
2014乡党委副书记党建工作汇报材料
2014/11/02 职场文书
2014幼儿园保育员工作总结
2014/11/10 职场文书
餐饮食品安全责任书
2015/01/29 职场文书
跑出一片天观后感
2015/06/08 职场文书
借钱欠条怎么写
2015/07/03 职场文书
redis的list数据类型相关命令介绍及使用
2022/01/18 Redis