什么是懒加载html
懒加载也叫延迟加载,即在须要的时候进行加载,随用随载。vue
为何须要懒加载webpack
在单页应用中,若是没有应用懒加载,运用webpack打包后的文件将会异常的大,形成进入首页时,须要加载的内容过多,延时过长,不利于用户体验,而运用懒加载则能够将页面进行划分,须要的时候加载页面,能够有效的分担首页所承担的加载压力,减小首页加载用时web
如何与webpack配合实现组件懒加载vuex
一、在webpack配置文件中的output路径配置chunkFilename属性npm
output: {
path: resolve(__dirname, 'dist'),
filename: options.dev ? '[name].js' : '[name].js?[chunkhash]',
chunkFilename: 'chunk[id].js?[chunkhash]',
publicPath: options.dev ? '/assets/' : publicPath
},
chunkFilename路径将会做为组件懒加载的路径babel
二、配合webpack支持的异步加载方法异步
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']
}
}]
引言ui
而在webpack > 2的时代,vue作代码分割懒加载更加的easy,不须要loader,不须要require.ensure。spa
import解决一切。
分割层级
Vue代码分割懒加载包含以下几个层级:
一、 组件层级分割懒加载
二、 router路由层级
三、 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分割)就足够了。大型项目可能三者都会用到,但用法都很简单