vue缓存的keepalive页面刷新数据的方法
作者:Summer05 时间:2023-07-02 17:01:00
用到这个的业务场景是这样的:
a页面点击新建列表按钮进入到新建的页面b,填写b页面并点击b页面确认添加按钮,把这些数据带到a页面,填充到列表(数组),可以添加多条,
点击这条的时候进入到编辑页面,确认修改之后,回退到a页面,a页面需要更新这条数据
实现这个功能的时候,由于是路由页面之间的跳转,首先想到的方案有几个:1. 用sessionStorage本地存储;2. 用路由参数带过去;3. 用兄弟组件传值
由于是添加完之后如果按回退是需要退出整个页面,如果用路由跳转,会出现回退到编辑页面了,所以这个方法首先排除
用本地存储的时候,如果不加回退也会吧之前存的历史记录给带过来,所以最终选用了第三种方法
由于a页面需要缓存,所以用到了路由页面的缓存
router.js
{path: '/a',name: 'a',component: a,meta: {keepAlive: true}},
App.vue
<template>
<div id="app">
<keep-alive>
<router-view v-if="$routemetakeepAlive"></router-view>
</keep-alive>
<router-view v-if="!$routemetakeepAlive"></router-view>
</div>
</template>
由于用到了keepalive, 所以页面在再次加载的时候是不会触发created而是会触发activated的
所以接收数据,重置数据要写到activated方法下
a页面接收
更改用Vue.set()方法
调用方法:Vue.set( target, key, value )
target:要更改的数据源(可以是对象或者数组)
key:要更改的具体数据
value :重新赋的值
activated(){
let that = this
Self$on('detailShow',(data)=>{ // 接收
if(!dataisEdit){ // 是新增还是编辑--这个是在跳转的时候带过去的--新增/编辑页面也会根据这个显示内容有所区别
thataddParamspush(data)
thataddParams = Arrayfrom(new Set(thataddParamsSubsidyInfos)) // 为避免重复去个重
}else{
//thataddParams[thateditIndex] = data // 刚开始想通过直接修改,后来发现不行,因为页面是有缓存的,显示的还是未修改之前的
Vueset(thataddParams,thateditIndex,data) // 用set方法修改数据
}
})
},
b页面提交(新增/编辑)
submit(){
if(!thisdetailValidate()){ // 这个是表单校验,如果不通过不然提交
return;
}else{
Self$emit('detailShow',thisaddParams) // 事件分发
this$routerback();
}
}
vue 缓存的keepalive页面刷新数据的话,这个主要还是用到了Vue.set( target, key, value )方法
来源:https://www.cnblogs.com/leiting/p/9996677.html
标签:vue,keepalive,页面刷新
0
投稿
猜你喜欢
Golang中switch语句和select语句的用法教程
2023-09-02 09:09:06
在HTML中,常见的URL有多种表示方式:
2009-07-28 12:18:00
OpenCV半小时掌握基本操作之腐蚀膨胀
2023-05-29 08:14:35
python基于tkinter点击按钮实现图片的切换
2022-03-18 10:22:31
Pytorch从0实现Transformer的实践
2021-12-22 03:26:41
InnoDB的关键特性-插入缓存,两次写,自适应hash索引详解
2024-01-18 01:28:23
Python爬虫文件下载图文教程
2023-11-18 23:59:03
Python使用tkinter模块实现GUI界面的学生信息管理系统流程分步详解
2022-04-06 18:09:53
python数据预处理 :数据共线性处理详解
2022-06-29 09:46:24
python-pymysql获取字段名称-获取内容方式
2024-01-21 05:19:44
PHP PDOStatement::closeCursor讲解
2023-06-07 18:23:31
MySQL数据库的root口令恢复方法总结
2009-08-19 09:03:00
在asp中通过vbs类实现rsa加密与解密
2010-05-27 12:18:00
pytorch实现图像识别(实战)
2022-10-03 01:19:03
详解Pymongo常用查询方法总结
2022-06-01 09:13:30
python学习之whl文件解释与安装详解
2021-11-01 18:09:14
mysql基础:mysqld_safe 启动执行流程详解
2024-01-14 23:33:57
[js效果] 图片加载进度实时显示
2007-09-12 19:27:00
如何在django里上传csv文件并进行入库处理的方法
2022-02-07 00:19:31
MySQL数据库事务transaction示例讲解教程
2024-01-27 06:43:04