it编程 > 编程语言 > Javascript

Vue3中keep-alive的使用及注意事项说明

9人参与 2025-04-24 Javascript

vue3中keep-alive使用及注意事项

keep-alive 是 vue 内置的一个抽象组件,用于缓存不活动的组件实例,避免重复渲染,提高性能。

以下是它的详细用法和注意事项:

基本用法

<template>
  <!-- 基本用法 -->
  <keep-alive>
    <component :is="currentcomponent"></component>
  </keep-alive>

  <!-- 缓存特定组件 -->
  <keep-alive include="compa,compb" exclude="compc">
    <router-view></router-view>
  </keep-alive>
</template>

主要功能

核心属性

生命周期钩子

keep-alive 缓存的组件会触发特有的生命周期钩子:

import { onactivated, ondeactivated } from 'vue'

export default {
  setup() {
    onactivated(() => {
      console.log('组件被激活')
    })
    
    ondeactivated(() => {
      console.log('组件被停用')
    })
  }
}

与 vue router 结合使用

<template>
  <keep-alive :include="cachedviews">
    <router-view v-slot="{ component }">
      <transition name="fade">
        <component :is="component" />
      </transition>
    </router-view>
  </keep-alive>
</template>

<script>
import { ref } from 'vue'
export default {
  setup() {
    const cachedviews = ref(['home', 'user'])
    return { cachedviews }
  }
}
</script>

注意事项

组件必须有 name 选项includeexclude 匹配的是组件的 name 选项

动态组件切换问题

<keep-alive><comp :key="id"></comp></keep-alive>
<comp v-if="show"></comp>

内存占用

数据更新时机

滚动行为

onactivated(() => {
  window.scrollto(0, 0)
})

与 transition 一起使用

<router-view v-slot="{ component }">
  <transition name="fade">
    <keep-alive>
      <component :is="component" />
    </keep-alive>
  </transition>
</router-view>

最佳实践

const routes = [
  {
    path: '/user',
    component: user,
    meta: { keepalive: true }
  }
]

通过合理使用 keep-alive,可以显著提升应用性能,特别是在移动端或需要频繁切换视图的场景中。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)
打赏 微信扫一扫 微信扫一扫

您想发表意见!!点此发布评论

推荐阅读

vue部署到线上为啥会出现404的原因分析及解决

04-24

使用Vue构建动态表单生成器的实现步骤

04-24

Vue中SSR的作用是什么

04-24

vue + element-plus自定义表单验证(修改密码业务)的示例

04-24

如何解决前端使用Axios时的跨域问题

04-24

vue实现自定义颜色选择器

04-24

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论