Vue keep-alive组件的使用及如何清除缓存

 更新时间:2023年10月14日 16:16:06   作者:PikY~  
本文介绍了Vue keep-alive组件的使用及如何清除缓存,给大家分享清除缓存的几种方法,结合实例代码给大家讲解的非常详细,需要的朋友跟随小编一起看看吧

1. keepAlive

在router的js文件中加入keepAlive

{
	path: "/A",
	name: 'A',
	meta:{ 
    	name: 'A' ,
   		keepAlive: false ,
	},
    component: resolve => require(['../A.vue'], resolve)
},
{
    path: "/B",
    name: 'B',
    meta:{ 
   		name: 'B' ,
   		keepAlive: true ,
   	},
    component: resolve => require(['../B.vue'], resolve)
},
{
    path: "/C",
    name: 'C',
    meta:{ 
   		name: 'C' ,
   		keepAlive: false,
   	},
    component: resolve => require(['../C.vue'], resolve)
},

在APP.vue中加入以下代码

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

2. 清除缓存的几种方法

有A,B,C三个组件需要在B组件中加入缓存,从组件B跳转组件C再从组件C跳转组件B缓存保留,但从组件B跳转到组件A后将组件B的缓存清除。

第一种用直接暴力法,在组件切换之后直接刷新

在组件B中加入beforeRouteLeave()方法和Watch监听事件

watch: {
	$route(to, from) {
		if(from.name === 'A'){
			this.route = from.name
			//如果是组件A跳转到的组件B,将组件B刷新
			this.$router.go(0);
		}
	},
},
//组件B跳转后将组件B的 keepAlive 值设置为false
beforeRouteLeave(to, from, next) {
	from.meta.keepAlive = false
	next()
}

watch: {
	$route(to, from) {
		if(from.name === 'A'){
			this.route = from.name
			//如果是组件A跳转到的组件B,将组件B刷新
			this.$router.go(0);
		}
	},
},
//组件B跳转后将组件B的 keepAlive 值设置为false
beforeRouteLeave(to, from, next) {
	from.meta.keepAlive = false
	next()
}

组件B跳转到组件C组件B的缓存不清除,在组件C中加入beforeRouteLeave()方法

beforeRouteLeave (to, from, next) {
	//若从组件C跳转到组件B, 将组件B的 keepAlive 值为true
	to.meta.keepAlive = true
	next()
}

第二种方法用$vnode方法获取DOM元素,将缓存清除

组件B中加入beforeRouteLeave()方法

beforeRouteLeave(to, from, next) {
	if (to.path == "/C") { //这里的路径是要跳转的需要缓存的路径
		from.meta.keepAlive = true;
	} else {
		let Vnode = this.$vnode;
		let parentVnode = Vnode && Vnode.parent;
		if (parentVnode && parentVnode.componentInstance && parentVnode.componentInstance.cache) {
			var key = Vnode.key == null ? Vnode.componentOptions.Ctor.cid + (Vnode.componentOptions.tag ? `::${Vnode.componentOptions.tag}` : '') : Vnode.key;
			var cache = parentVnode.componentInstance.cache;
			var keys  = parentVnode.componentInstance.keys;
			if (cache[key]) {
				this.$destroy();
				if (keys.length) {
					var index = keys.indexOf(key);
					if (index > -1) {
						keys.splice(index, 1);
					}
				}
				cache[key] = null;
			}
		}
	}
	next();
}

在组件C中加入beforeRouteLeave()和beforeRouteEnter()方法

data(){
	return{
		Fromvnode: null
	}
}
beforeRouteEnter(to, from, next) {
	next(vm => {
		vm.Fromvnode = from
	})
},
beforeRouteLeave(to, from, next) {
	if (to.path !== '/B') {
		this.Fromvnode.meta.keepAlive = false
	}
	next()
}

到此这篇关于Vue keep-alive组件的使用以及清除缓存的方法的文章就介绍到这了,更多相关Vue keep-alive组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue Autocomplete 自动完成功能简单示例

    Vue Autocomplete 自动完成功能简单示例

    这篇文章主要介绍了Vue Autocomplete 自动完成功能,结合简单示例形式分析了Vue使用el-autocomplete组件实现自动完成功能相关操作技巧,需要的朋友可以参考下
    2019-05-05
  • 浅析对Vue中keep-alive缓存组件的理解

    浅析对Vue中keep-alive缓存组件的理解

    <keep-alive> 是一个抽象组件,用于将其内部的组件保留在内存中,而不会重新渲染,这意味着当组件在<keep-alive> 内部切换时,其状态将被保留,而不是被销毁和重新创建,这篇文章主要介绍了Vue中的keep-alive缓存组件的理解,需要的朋友可以参考下
    2024-01-01
  • vue3+vite2+mqtt连接遇到的坑及解决

    vue3+vite2+mqtt连接遇到的坑及解决

    这篇文章主要介绍了vue3+vite2+mqtt连接遇到的坑及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 基于Vue实现微前端的示例代码

    基于Vue实现微前端的示例代码

    这篇文章主要介绍了基于Vue实现微前端的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • vue 当中组件之间共享数据的实现方式

    vue 当中组件之间共享数据的实现方式

    这篇文章主要介绍了vue 当中组件之间共享数据的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • 关于vue-cli 3配置打包优化要点(推荐)

    关于vue-cli 3配置打包优化要点(推荐)

    这篇文章主要介绍了vue-cli 3配置打包优化要点,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • vue-calendar-component 封装多日期选择组件的实例代码

    vue-calendar-component 封装多日期选择组件的实例代码

    这篇文章主要介绍了vue-calendar-component 封装多日期选择组件,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • Vue.js基础知识小结

    Vue.js基础知识小结

    本文主要介绍了Vue.js的相关知识。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • vue项目中使用lib-flexible解决移动端适配的问题解决

    vue项目中使用lib-flexible解决移动端适配的问题解决

    这篇文章主要介绍了vue项目中使用lib-flexible解决移动端适配的问题解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • vue2.0实现移动端的输入框实时检索更新列表功能

    vue2.0实现移动端的输入框实时检索更新列表功能

    最近小编在做vue2.0的项目,遇到移动端实时检索搜索更新列表的效果,下面脚本之家小编给大家带来了vue2.0 移动端的输入框实时检索更新列表功能的实例代码,感兴趣的朋友参考下吧
    2018-05-05

最新评论