源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-03-07 10:03 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Vue代码分割懒加载的实现方法
[b]什么是懒加载[/b] 懒加载也叫延迟加载,即在需要的时候进行加载,随用随载。 [b]为什么需要懒加载[/b] 在单页应用中,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,延时过长,不利于用户体验,而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时 [b]如何与webpack配合实现组件懒加载[/b] [b]1、在webpack配置文件中的output路径配置chunkFilename属性[/b]
output: {
path: resolve(__dirname, 'dist'),
filename: options.dev ? '[name].js' : '[name].js?[chunkhash]',
chunkFilename: 'chunk[id].js?[chunkhash]',
publicPath: options.dev ? '/assets/' : publicPath
},
chunkFilename路径将会作为组件懒加载的路径 [b]2、配合webpack支持的异步加载方法[/b] [list] [*]resolve => require([URL], resolve), 支持性好[/*] [*]() => system.import(URL) , webpack2官网上已经声明将逐渐废除, 不推荐使用[/*] [*]() => import(URL), webpack2官网推荐使用, 属于es7范畴, 需要配合babel的syntax-dynamic-import插件使用, 具体使用方法如下[/*] [/list]
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']
}
}]
[b]引言[/b] 而在webpack > 2的时代,vue做代码分割懒加载更加的easy,不需要loader,不需要require.ensure。 import解决一切。 [b]分割层级[/b] Vue代码分割懒加载包含如下几个层级:       1、 组件层级分割懒加载       2、 router路由层级       3、 Vuex 模块 [b]组件层级代码分割[/b]
//全局组件
Vue.component('AsyncComponent', () => import('./AsyncComponent'))

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

// 如果不是default导出的模块
new Vue({
 // ...
 components: {
 'AsyncComponent': () => import('./AsyncComponent').then({ AsyncComponent }) => AsyncComponent
 }
})
[b]路由层级代码分割[/b]
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)
})
[b]总结[/b] 在一般项目中,我们按照router和components层面分割(或者只使用router分割)就足够了。大型项目可能三者都会用到,但用法都很简单,不是么? 好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部