Vue代码分割懒加载的实现方法
2017-11-23 08:42
706 查看
什么是懒加载
懒加载也叫延迟加载,即在需要的时候进行加载,随用随载。
为什么需要懒加载
在单页应用中,如果没有应用懒加载,运用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(详解vue2路由vue-router配置(懒加载)" target=_blank>, 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分割)就足够了。大型项目可能三者都会用到,但用法都很简单,不是么?
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
- [url=https://www.geek-share.com/detail/2702614601.html]详解vue2路由vue-router配置(懒加载)
- [url=https://www.geek-share.com/detail/2701768082.html]vue2组件实现懒加载浅析
- Vue自定义图片懒加载指令v-lazyload详解
- vue2笔记 ― vue-router路由懒加载的实现
- Vue.js如何实现路由懒加载浅析
- 浅谈vue中使用图片懒加载vue-lazyload插件详细指南
相关文章推荐
- 在webpack中使用Code Splitting--代码分割来实现vue中的懒加载
- react 实现页面代码分割、按需加载的方法
- jquery ajax局部加载方法详解(实现代码)
- 模拟jQuery中的ready方法及实现按需加载css,js实例代码
- Vue.js 的移动端组件库mint-ui实现无限滚动加载更多的方法
- vue+webpack实现异步组件加载的方法
- vue路由懒加载的实现方法
- React配合Webpack实现代码分割与异步加载
- ListView异步加载图片是非常实用的方法,凡是是要通过网络获取图片资源一般使用这种方法比较好,用户体验好,下面就说实现方法,先贴上主方法的代码:
- 基于vue和react的spa进行按需加载的实现方法
- VUE页面实现加载外部HTML方法
- 模拟jQuery中的ready方法及实现按需加载css,js实例代码
- C#实现图片分割方法与代码
- vue实现图片加载完成前的loading组件方法
- vue项目tween方法实现返回顶部的示例代码
- jquery ajax局部加载方法详解(实现代码)
- Vue-Router实现页面正在加载特效方法示例
- 模拟jQuery中的ready方法及实现按需加载css,js实例代码
- vue移动端下拉刷新和上拉加载的实现代码
- TensorFlow使用C++加载使用训练好的模型,.cc文件代码实现的相关类及方法总结