时间:2021-05-26
什么是懒加载
懒加载也叫延迟加载,即在需要的时候进行加载,随用随载。
为什么需要懒加载
在单页应用中,如果没有应用懒加载,运用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支持的异步加载方法
引言
而在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 }})路由层级代码分割
Vuex 模块代码分割,vuex中有动态注册模块方法,同时也是加上import
const store = new Vuex.Store()import('./store/test').then(testModule => { store.registerModule('test', testModule)})总结
在一般项目中,我们按照router和components层面分割(或者只使用router分割)就足够了。大型项目可能三者都会用到,但用法都很简单,不是么?
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近研究了vue性能优化,涉及到vue异步组件和懒加载。一番研究得出如下的解决方案。原理:利用webpack对代码进行分割是懒加载的前提,懒加载就是异步调用组件
本文介绍了vue的路由懒加载,分享给大家,具体如下:我们可以把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件。component可以
vue-router路由懒加载和权限控制,今天刚好搞了一个基于nodetoken验证的小demo所以下面介绍下,路由懒加载1、为什么要使用路由懒加载呢用vue.
未使用懒加载importVuefrom'vue';importRouterfrom'vue-router';importHelloWorldfrom'@comp
一个页面图片比较多的时候,需要对界面的图片进行懒加载处理,今天遇到了,做个懒加载的笔记。1,需要安装vue的懒加载插件。npminstallvue-lazylo