Vue组件(三)——keep-alive性能优化

keep-alive标签,是vue自带的标签。

很多时候页面是需要进行数据缓存的。在vue项目中,这个功能的应用极为简单,因为vue中已经定义好了keep-ailve标签,只需要在项目入口处,使用keep-alive标签包括项目即可。

例如,vue的项目入口都是App.vue组件(定义在main.js中),因此:

<template>
  <div id="app">
    <!-- keep-alive是vue自带标签。路由内容被加载后,即放入内存中,下次进入路由不需再次加载
    使用该组件后会多两个钩子函数:activated、deactivated。页面加载和卸载时执行 -->
    <!-- 除了Detail页面,其他都会被缓存。不过每次加载Detail都会再次ajax请求。
    exclude值的页面,不会使用组件keep-alive,因此activated和deactivated不会生效 -->
    <keep-alive exclude="Detail">
       <!-- rooterview表示的是当前路由地址所对应的内容
       路由地址定义在router/index.js中 -->
      <router-view/>
    </keep-alive>
  </div>
</template>

<script>
export default {
  name: 'App'
}
</script>

<style>

</style>

 

keep-alive的钩子

activated:使用keep-alive标签时才会被激活。页面加载时执行,可以用于数据渲染。由于使用了keep-alive后,ajax的请求数据会被浏览器缓存,当需要数据重新渲染时(如去哪儿网城市不同,景点数据不同)也不会重新请求数据。这时,需要将ajax请求函数放在activated中即可。

deactivated:使用keep-alive标签时才会被激活。页面卸载时执行。

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值