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
投稿
猜你喜欢
关于adfuller函数返回值的参数说明与记录
2023-03-07 13:33:14
10分钟学会Google Map API (一)
2009-06-07 18:17:00
MySQL之主键索引排序失效问题
2024-01-19 10:38:53
python绘制堆叠条形图介绍
2021-07-01 23:12:36
VBScript中清除数组元素Erase语句
2008-06-27 13:05:00
一文详解kubernetes 中资源分配的那些事
2024-05-22 17:47:57
python“静态”变量、实例变量与本地变量的声明示例
2021-11-16 23:17:28
使用堆实现Top K算法(JS实现)
2024-06-17 00:38:07
asp如何遍历Cookies集合?
2009-11-08 19:07:00
vitrualBox+ubuntu16.04安装python3.6最新教程及详细步骤
2021-06-26 05:34:38
一文读懂JS中的var/let/const和暂时性死区
2024-04-19 10:06:05
python使用tkinter模块实现文件选择功能
2022-06-18 18:35:56
js判断undefined类型,undefined,null, 的区别详细解析
2024-05-09 10:34:26
JavaScript遍历求解数独问题的主要思路小结
2023-10-13 16:41:14
Webpack中publicPath使用详解
2024-04-28 10:21:11
基于CentOS搭建Python Django环境过程解析
2021-09-10 07:14:58
利用Python正则表达式过滤敏感词的方法
2023-05-07 05:05:18
Python利用format函数实现对齐打印(左对齐、右对齐与居中对齐)
2021-07-30 05:16:16
MySQL 导入慢的解决方法
2024-01-22 12:08:42
谈谈网页设计中的字体应用 (3) 实战应用篇·上
2009-11-24 13:09:00