浅析--路由懒加载


一、 什么是懒加载

      懒加载也叫延迟加载,即在需要的时候进行加载,随用随载。

二、为什么需要懒加载

      在单页应用中,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多,延时过长,不利于用户体验,而运用懒加载则可以将页面进行划分,需要的时候加载页面,可以有效的分担首页所承担的加载压力,减少首页加载用时。

三、具体实例中实现懒加载

  1、路由中配置异步组件

1
2
3
4
5
6
7
8
9
10
export  default  new  Router({
     routes: [
         {
             mode:  'history' ,
             path:  '/my' ,
             name:  'my' ,
             component:  resolve => require([ '../page/my/my.vue' ], resolve), //懒加载
         },
     ]
})

  2、实例中配置异步组件

1
2
3
4
components: {
         historyTab: resolve => {require([ '../../component/historyTab/historyTab.vue' ], resolve)}, //懒加载
         //historyTab: () => import('../../component/historyTab/historyTab.vue')
     },

  3、全局注册异步组件

1
2
3
Vue.component( 'mideaHeader' , () => {
     System. import ( './component/header/header.vue' )
})

四、配置异步组件实现懒加载的问题分析

  1、多次进出同一个异步加载页面是否会造成多次加载组件?

  答:否,首次需要用到组件时浏览器会发送请求加载组件,加载完将会缓存起来,以供之后再次用到该组件时调用

  2、在多个地方使用同一个异步组件时是否造成多次加载组件?如:

  答:否,理由同上

  3、如果在两个异步加载的页面中分别同步与异步加载同一个组件时是否会造成资源重用?


  答: 会, 将会造成资源重用,          解决方案: 组件开发时, 如果根页面没有导入组件的情况下,而是在其他异步加载页面中同时用到组件, 那么为实现资源的最大利用,在协同开发的时候全部人都使用异步加载组件

 4、在异步加载页面中载嵌入异步加载的组件时对页面是否会有渲染延时影响?

  答:会, 异步加载的组件将会比页面中其他元素滞后出现, 页面会有瞬间闪跳影响;

  解决方案:因为在首次加载组件的时候会有加载时间, 出现页面滞后, 所以需要合理的进行页面结构设计, 避免首次出现跳闪现象;

六、懒加载的最终实现方案

  1、路由页面以及路由页面中的组件全都使用懒加载

  优点:(1)最大化的实现随用随载

     (2)团队开发不会因为沟通问题造成资源的重复浪费    

  缺点:(1)当一个页面中嵌套多个组件时将发送多次的http请求,可能会造成网页显示过慢且渲染参差不齐的问题

  2、路由页面使用懒加载, 而路由页面中的组件按需进行懒加载, 即如果组件不大且使用不太频繁, 直接在路由页面中导入组件, 如果组件使用较为频繁使用懒加载

  优点:(1)能够减少页面中的http请求,页面显示效果好

  缺点:(2)需要团队事先交流, 在框架中分别建立懒加载组件与非懒加载组件文件夹

  3、路由页面使用懒加载,在不特别影响首页显示延迟的情况下,根页面合理导入复用组件,再结合方案2

  优点:(1)合理解决首页延迟显示问题

     (2)能够最大化的减少http请求, 且做其他他路由界面的显示效果最佳

  缺点:(1)还是需要团队交流,建立合理区分各种加载方式的组件文件夹


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM