Vue——Router(路由懒加载)

常用的路由懒加载方式:

    1、vue异步组件(异步加载)

    2、路由懒加载(使用import)

 

vue异步组件(异步加载)

vue-router配置路由 , 使用vue的异步组件技术 ,可以实现按需加载 。
但是,这种情况下,webpack打包时一个组件生成一个js文件,即每加载一个组件都需要加载一个新的js文件

/* vue异步组件 */
{
   path: '/home',
   name: 'home',
   component: resolve => require(['@/page/home'],resolve)
},{
   path:'/about',
   name:'about',
   component:resolve => require(['@/page/about'],resolve)
},{
   path:'/description',
   name:'description',
   component:resolve => require(['@/page/description'],resolve)
}

路由懒加载(使用import)

vue-router配置路由 , 使用import按需引入,没有指定webpackChunkName时,每个组件打包成一个js;指定webpackChunkName时,相同webpackChunkName名字的组件,会合并打包成一个js文件,把组件按组分块。

/* 路由懒加载 */
//不指定webpackChunkName(每个分别打包成一个js文件)
{
   path: '/home',
   name: 'home',
   component: import('../page/home')
},{
   path:'/about',
   name:'about',
   component:import('../page/about')
},{
   path:'/description',
   name:'description',
   component:import('../page/description')
}
//指定webpackChunkName(合并打包成一个js文件)
{
   path: '/home',
   name: 'home',
   component: import(/* webpackChunkName: 'home' */ '../page/home')
},{
   path:'/about',
   name:'about',
   component:import(/* webpackChunkName: 'home' */ '../page/about')
},{
   path:'/description',
   name:'description',
   component:import(/* webpackChunkName: 'home' */ '../page/description')
}

个人认为,指定webpackChunkName时,使用频率高的组件、同一功能的组件、有上下游关系的组件均可以合并打包到一个组件中,这样在加载一个功能组件时,同功能的其他组件均已加载,使用感觉更流畅。而功能单一且使用频率很低的组件就可以单独打包成一个,不需要时就不用加载。

Vue 组件懒加载路由懒加载都是为了优化应用性能而采用的技术手段,通过按需加载的方式减少初始加载时间。 ### Vue 组件懒加载 **组件懒加载**是指当某个特定的组件需要被渲染时才去动态导入该组件,而不是一开始就将所有组件打包在一起。这种方式可以显著减小初次加载的应用体积,提升用户体验。在 Vue 中通常结合 `import()` 函数来实现: ```javascript const MyComponent = () => import('./MyComponent.vue'); ``` 在这里,`import()` 返回的是一个 Promise 对象,只有当组件真正需要用到的时候才会触发网络请求下载组件代码并解析执行。 --- ### 路由懒加载 对于基于单页应用程序(SPA) 的项目来说,如果所有的页面都一次性全部加载到内存里会非常耗费资源,并且增加首屏加载耗时。因此我们可以对每个单独的路由也采取同样的策略——仅在其对应的路径访问时再进行加载。 以 vue-router 配置为例: ```javascript { path: '/about', name: 'About', // 使用箭头函数配合异步引入完成懒加载效果 component: () => import(/* webpackChunkName: "about" */ '../views/AboutView.vue') } ``` 这里的 `webpackChunkName` 注释可以让 Webpack 将这些懒加载的内容分割成独立文件以便于更精细地管理缓存等操作。 这种技术不仅能有效降低首页包大小,同时还能提高 SEO 表现(针对服务端渲染的情况),并且有助于长期依赖更新后的增量发布流程简化维护工作量等问题解决。 --- #### 实际应用场景对比分析 | 特点 | 组件懒加载 | 路由懒加载 | |-------------------|--------------------------------------------|------------------------------------------| | **作用范围** | 单独某个组件 | 整个视图及其包含的所有组件 | | **适用场景** | 局部区域、非关键功能模块 | 页面级别的划分 | 无论是哪种形式,在实际开发过程中都需要权衡好项目的复杂程度以及用户交互习惯等因素综合考虑是否适合采用这样的机制来进行优化处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值