继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

vue的路由懒加载

慕斯709654
关注TA
已关注
手记 280
粉丝 37
获赞 183

路由懒加载官方介绍


非懒加载写法:

import Login from '@/components/Login'

所有路由涉及到的文件会被打包到 app.xxx.js 中

懒加载写法:

const Login = () => import('@/components/Login')

这里要扩展说明的是 把组件按组分块

const Login = () => import(/* webpackChunkName: "group-index" */ '@/components/Login')

这样去写的话,那么 webpackChunkName: "group-index" 的所有路由组件就会被打包到一起,如 0.faxxx.js,如果有多个组,那么就是依次 1.xxx.js,2.xxx.js。
比方说 用户相关的路由为一组,设置相关的路由为一组等,打包完成后的打印日志能看到每个组对应的js文件:
5c7b3e5a0001ec6c06540092.jpg

这样的话,首屏加载的时候就不会一次性下载所有路由文件,而是根据当前页面下载对应的文件,等到用户首次跳转到另一个路由组的时候再进行下载。

比如 编译后,我首次加载主页,那么会下载 group-index 对应的路由文件资源,之后跳转用户列表页,再下载 group-user 路由文件资源。
5c7b3e5b00016ef909260393.jpg

5c7b3e5b000148a609700205.jpg

这样的话初始化的时候会比之前稍微快些,因为首次加载少下载了一些资源。

但副作用就是,当你跳转到新的分组页面的时候,会卡那么一下,因为需要等待下载路由文件资源,等待时间根据用户网路和当前路由文件资源大小决定,所以路由文件组的分割需要开发者自己进行判断。

个人建议打包后如果超过1M了可以考虑拆分一下,网速慢的话可能下载需要1~2s时间。

作者:小小灬厮

原文出处:https://www.cnblogs.com/cielsys/p/10457945.html  

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP