zoukankan      html  css  js  c++  java
  • vue 缓存的keepalive页面刷新数据

    用到这个的业务场景是这样的:

    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="$route.meta.keepAlive"></router-view>
        </keep-alive>
        <router-view v-if="!$route.meta.keepAlive"></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(!data.isEdit){ // 是新增还是编辑--这个是在跳转的时候带过去的--新增/编辑页面也会根据这个显示内容有所区别
                   that.addParams.push(data)
                   that.addParams = Array.from(new Set(that.addParams.SubsidyInfos)) // 为避免重复去个重
                }else{
             // that.addParams[that.editIndex] = data // 刚开始想通过直接修改,后来发现不行,因为页面是有缓存的,显示的还是未修改之前的 Vue.set(that.addParams,that.editIndex,data) // 用set方法修改数据 } })
    },

    b页面提交(新增/编辑)

    submit(){
            if(!this.detailValidate()){ // 这个是表单校验,如果不通过不然提交
              return;
            }else{
              Self.$emit('detailShow',this.addParams) // 事件分发
              this.$router.back();
    
            }
          }

    vue 缓存的keepalive页面刷新数据的话,这个主要还是用到了Vue.set( target, key, value )方法

  • 相关阅读:
    Vue less使用scope时渗入修改子组件样式
    Spring容器初始话原理图
    Java的动态代理
    Spring_xml和注解混合方式开发
    Spring_xml方式开发
    Spring入门初体验
    数论
    虚拟IP和IP漂移
    字符串hash + 二分答案
    字符串hash
  • 原文地址:https://www.cnblogs.com/leiting/p/9996677.html
Copyright © 2011-2022 走看看