像vue这种单页面应用,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,时间过长,会出啊先长时间的白屏,即使做了loading也是不利于用户体验,而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时
1.vue异步组件
2.es提案的import()
3.webpack的require,ensure()
vue异步组件
使用vue的异步组件技术 , 可以实现按需加载
const router = new VueRouter({
routes: [
{ path: '/foo', component:resolve=>(require(["./Foo.vue"],resolve)) }
]
})
es提案的import()
const 组件名=() => import('组件路径')
const router = new VueRouter({
routes: [
{ path: '/foo', component: () => import(/* webpackChunkName: "group-foo" */ './Foo.vue') }
]
})
webpack的require,ensure()
// r就是resolve
const list = r => require.ensure([], () => r(require('../components/list/list')), 'list');
// 路由也是正常的写法 这种是官方推荐的写的 按模块划分懒加载
const router = new Router({
routes: [
{
path: '/list/blog',
component: list,
name: 'blog'
}
]
})
注:uniapp默认就是懒加载如果想加快速度可以在打包完成之后,将打包好的index.html 里面 的 js文件,除了chunk-vendor 和index ,其他的都删除,就行了