路由懒加载与组件懒加载

路由懒加载与组件懒加载

一、为什么要使用路由懒加载
  为给客户更好的客户体验,首屏组件加载速度更快一些,解决白屏问题。

二、定义

懒加载简单来说就是延迟加载或按需加载,即在需要的时候的时候进行加载。

三、使用

常用的懒加载方式有两种:即使用vue异步组件 和 ES中的import

1、不用懒加载,vue中路由代码如下:
     
import Vue from ‘vue’
import Router from ‘vue-router’
import HelloWorld from ‘@/components/HelloWorld’

            Vue.use(Router)

            export default new Router({
              routes: [
                {
                  path: '/',
                  name: 'HelloWorld',
                  component:HelloWorld
                }
              ]
            })==

2、vue异步组件实现懒加载
 方法如下:component:resolve=>(require([‘需要加载的路由的地址’]),resolve)
 import Vue from ‘vue’
import Router from ‘vue-router’
  /* 此处省去之前导入的HelloWorld模块 */
Vue.use(Router)

export default new Router({
routes: [
{
path: ‘/’,
name: ‘HelloWorld’,
component: resolve=>(require(["@/components/HelloWorld"],resolve))
}
]
})

3、ES 提出的import方法,(------最常用------)
    方法如下:const HelloWorld = ()=>import(‘需要加载的模块地址’)
    (不加 { } ,表示直接return)

   
import Vue from ‘vue’
import Router from ‘vue-router’

Vue.use(Router)

const HelloWorld = ()=>import("@/components/HelloWorld")
export default new Router({
routes: [
{
path: ‘/’,
name: ‘HelloWorld’,
component:HelloWorld
}
]
})

require: 运行时调用,理论上可以运用在代码的任何地方,
import:编译时调用,必须放在文件开头

懒加载:component: resolve => require([’@/view/index.vue’], resolve)
用require这种方式引入的时候,会将你的component分别打包成不同的js,加载的时候也是按需加载,只用访问这个路由网址时才会加载这个js

非懒加载:component: index
如果用import引入的话,当项目打包时路由里的所有component都会打包在一个js中,造成进入首页时,需要加载的内容过多,时间相对比较长

vue的路由配置文件(routers.js),一般使用import引入的写法,当项目打包时路由里的所有component都会打包在一个js中,在项目刚进入首页的时候,就会加载所有的组件,所以导致首页加载较慢,

而用require会将component分别打包成不同的js,按需加载,访问此路由时才会加载这个js,所以就避免进入首页时加载内容过多。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值