vue中keepAlive组件的作用及使用方式

在面试的时候,很多面试官再问vue的时候可能就会提一嘴,你知道keep-alive有什么作用吗?
在这里插入图片描述
keep-alive是vue内置的一个组件,而这个组件的作用就是能够缓存不活动的组件,我们能够知道,一般情况下,组件进行切换的时候,默认会进行销毁,如果有需求,某个组件切换后不进行销毁,而是保存之前的状态,那么就可以利用keep-alive来实现

我这里利用脚手架创建项目后会生成home和about两个组件,并且通过路由进行切换

home组件
<template>
  <div class="home">
    <input type="text">
  </div>
</template>

<script>
// @ is an alias to /src
import HelloWorld from '@/components/HelloWorld.vue'

export default {
  name: 'home',
  components: {
    HelloWorld
  }
}
</script>

我在home组件中写了一个input输入框

about组件
<template>
  <div class="about">
    <input type="text">
  </div>
</template>
<script>
export default {
  name:"about"
}
</script>

同样的about组件也放了一个输入框

在这里插入图片描述

当我们在home组件的输入框输入一些内容的时候,然后切换到about组件,在切换回home组件,我们会发现之前输入的内容被清空了,其实也容易理解,就是当切换到about组建的时候,home组件就被销毁了,输入框的值自然被清空了

在这里插入图片描述

我在home组件写了destroyed生命周期函数

在这里插入图片描述

当切换到about组件的时候home组件的destroyed就触发了,所以home组件被销毁了

那么此时我们就可以利用keep-alive组件进行包裹router-view组件,将不活动的组件缓存起来

App组件
<template>
  <div id="app">
    <div id="nav">
      <router-link to="/">Home</router-link> |
      <router-link to="/about">About</router-link>
    </div>
    <keep-alive>
      <router-view />
    </keep-alive>
    
  </div>
</template>

写完之后会发现当切换到about组件时,home组件中的destroyed并没有触发,并且home组件的值也保存了下来

在这里插入图片描述

但是这样也肯定不好,我们会发现,about组件的值也被缓存了,就是所有的路由组件都被缓存了,严重浪费性能,而且也不符合需求,我们现在只想缓存home组件

在keep-alive上有两个属性

字符串或正则表达式。只有匹配的组件会被缓存。

  • include 值为字符串或者正则表达式匹配的组件name会被缓存。
  • exclude 值为字符串或正则表达式匹配的组件name不会被缓存。

首先利用include实现,匹配到组件中定义的name,将进行缓存

<keep-alive include="home">
   <router-view />
</keep-alive>

在这里插入图片描述

我们会发现home已经被缓存了,但是about没有被缓存

而exclude就是排除了,这个就不在演示了,很简单,除了这个我们还可以利用路由中的meta属性来控制

{
      path: '/',
      name: 'home',
      meta:{
        keepAlive:true
      },
      component: Home
    }

将home的路由规则钟的meta添加keepAlive属性为true,也就是当前路由组件要进行缓存

keep-alive代码可以结合v-if进行包裹,如果meta中的keepAlive为true进行缓存,否侧不进行缓存,这样可以更灵活一些

<keep-alive>
      <router-view v-if="$route.meta.keepAlive" />
</keep-alive>
<router-view v-if="!$route.meta.keepAlive" />

这样组件的缓存是实现了,但是还是会有一些问题,就是因为组件被缓存,并没有被销毁,所以组件在切换的时候也就不会被重新创建,自然也就不会调用created等生命周期函数,所以此时要使用activated与deactivated来获取当前组件是否处于活动状态

我在home组件里面写入了activated与deactivated生命周期函数

activated(){
    console.log("哎呀看见我了")
    console.log("----------activated--------")
  },
  deactivated(){
    console.log("讨厌!!你又走了")
    console.log("----------deactivated--------")
  }

在这里插入图片描述

通过上面的gif图相信已经看得很清楚了,此时keep-Alive也就差不多了
关注我,经常更新前端技术

  • 100
    点赞
  • 261
    收藏
    觉得还不错? 一键收藏
  • 19
    评论
### 回答1: 好的,关于用Vue实现keep-alive组件的问题,我可以给您回答。 在Vue,可以使用内置的keep-alive组件来实现组件缓存和复用的功能。使用keep-alive包裹的组件会被缓存起来,当组件被切换时,可以直接从缓存获取组件实例,避免了重复创建和销毁组件,提高了应用的性能。 以下是一个使用keep-alive组件的例子: ``` <template> <div> <keep-alive> <component :is="currentComponent"></component> </keep-alive> </div> </template> <script> export default { data() { return { currentComponent: 'ComponentA' } } } </script> ``` 在上面的例子,我们将一个动态组件包裹在keep-alive,并通过绑定is属性来指定当前显示的组件。当切换组件时,Vue会自动从缓存获取或销毁组件,实现了组件的缓存和复用。 ### 回答2: Vue的keep-alive组件是用来缓存动态组件的,可以提高性能和用户体验。下面是一个使用Vue实现keep-alive组件的步骤: 1. 首先,需要在Vue的根组件引入keep-alive组件,并在模板使用<keep-alive></keep-alive>标签包裹需要缓存的动态组件。 2. 在需要缓存的组件,可以通过设置<keep-alive>标签的include属性,指定需要缓存的组件。例如,<keep-alive :include="['组件A', '组件B']"></keep-alive>,表示只有组件A和组件B会被缓存,其他组件每次都会被重新创建。 3. 可以通过设置<keep-alive>标签的exclude属性,排除不需要被缓存的组件。例如,<keep-alive :exclude="['组件C', '组件D']"></keep-alive>,表示除了组件C和组件D,其他组件都会被缓存。 4. 可以通过设置<keep-alive>标签的max属性,控制最大缓存的组件实例数量。例如,<keep-alive :max="5"></keep-alive>,表示最多只缓存5个组件实例,超过数量的组件实例会被销毁。 5. 在需要缓存的动态组件,可以通过定义activated和deactivated生命周期钩子函数,来处理组件在被缓存和激活时的相关逻辑。例如,在activated生命周期钩子函数可以执行组件被激活时的一些操作。 通过以上步骤,我们可以使用Vue的keep-alive组件来缓存需要动态加载的组件,提高性能和用户体验。 ### 回答3: 在Vue,可以使用<keep-alive>组件来实现组件的缓存和复用。 首先,在需要进行缓存的组件外部包裹<keep-alive>标签。例如: ``` <template> <div> <keep-alive> <router-view></router-view> </keep-alive> </div> </template> ``` 然后,在需要被缓存的组件使用<keep-alive>的include属性来指定需要缓存的组件名称。例如: ``` <template> <div> <button @click="count++">{{ count }}</button> </div> </template> <script> export default { name: 'CachedComponent', data() { return { count: 0 } }, beforeRouteLeave(to, from, next) { if (to.name !== 'CachedComponent') { this.$destroy(); } next(); } } </script> ``` 在以上代码,定义了一个带有计数器的组件,并在beforeRouteLeave生命周期钩子实现了销毁组件的逻辑。这样,当从CachedComponent组件切换到其他组件时,CachedComponent组件会被销毁。 最后,在路由配置,将需要使用缓存功能的组件的name属性设置为需要缓存的组件名称。例如: ``` const router = new VueRouter({ routes: [ { path: '/', name: 'CachedComponent', component: CachedComponent }, { path: '/other', name: 'OtherComponent', component: OtherComponent } ] }) ``` 通过以上步骤,就可以在Vue实现组件的缓存和复用了。使用<keep-alive>组件包裹需要缓存的组件,设置include属性指定需要缓存的组件名称,将需要使用缓存的组件的name属性设置为需要缓存的组件名称。这样,在切换到其他组件并再次回到需要缓存的组件时,Vue会直接复用之前的组件实例,而不会重新创建。这样可以提高组件的渲染效率和用户体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值