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
  • asp之家 网络编程 m.aspxhome.com