135人参与 • 2025-04-24 • Javascript
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 缓存的组件会触发特有的生命周期钩子:
onactivated:组件被激活时调用(进入缓存组件)ondeactivated:组件被停用时调用(离开缓存组件)import { onactivated, ondeactivated } from 'vue'
export default {
setup() {
onactivated(() => {
console.log('组件被激活')
})
ondeactivated(() => {
console.log('组件被停用')
})
}
}<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 选项:include 和 exclude 匹配的是组件的 name 选项
动态组件切换问题:
key 属性强制重新渲染:<keep-alive><comp :key="id"></comp></keep-alive>
v-if 控制:<comp v-if="show"></comp>
内存占用:
max 属性限制缓存数量数据更新时机:
created/mounted 不会再次触发activated 中处理数据刷新逻辑滚动行为:
activated 中处理: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,可以显著提升应用性能,特别是在移动端或需要频繁切换视图的场景中。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论