Vue 状态存储和会话存储同步清空问题解决方案(最新推荐)

 更新时间:2024年12月16日 14:33:15   作者:前端糕手  
文章介绍了在使用Pinia定义的useHeaderTabStore中,tab状态通过会话存储初始化但未在退出登录时同步清空的问题,通过在PiniaStore中定义清空tab的函数,并在退出登录时调用该函数,可以确保状态和会话存储同步清空,避免内存中残留旧数据,感兴趣的朋友一起看看吧

问题描述:

   在使用 Pinia 定义的 useHeaderTabStore中,tab状态是通过会话存储(sessionStorage)初始化的。然而在退出登录时,即使清空了会话存储中的 tab数据,重新登录后页面上的 tab数据仍然存在,这是因为 Pinia 状态在内存中仍然保留了之前的数据,未重新获取会话存储的数据。

解决方法:

  • 在 Pinia Store 中定义一个清空 tab 的函数

    • 清空内存中 tab的状态变量。
    • 同时清空会话存储中的 tab数据。
  • 在退出登录函数中调用该清空函数

    • 这样可以确保状态和会话存储同步清空

状态存储文件:

const useHeaderTabStore=defineStore('headerTab',{
state:():any=>({
tab:sessionStorage.getItem('tab')?JSON.parse(sessionStorage.getItem('tab')||'{}'): [],
currentTab:{}
}),
getters:{
  getTab():any[]{
return this.tab
  }
},
actions:{
//添加的清除tab的函数
clearTab(){
  this.tab=[]
  sessionStorage.removeItem('tab');
},
//把tab通过sessionStorage存储起来然后赋值给tab变量
setTab(val:any){
    console.log(val,'headertab')
    this.currentTab=val
    const exists = this.tab.some((item:any) => item.path === val.path)
    if (!exists) {
      console.log('Adding new tab');
      this.tab.push(val);
      sessionStorage.setItem('tab',JSON.stringify(this.tab))
    } else {
      console.log('Tab already exists');
    }
  }
}
})
export default useHeaderTabStore

退出登录函数

//一开始的问题函数
  function logout() {
  router.replace('/homePage');
 sessionStorage.removeItem('tab');
}
//修改成调用清除函数
function logout() {
  const headerTabStore = useHeaderTabStore(); // 引用 Pinia Store
  headerTabStore.clearTab(); // 调用清空函数
  router.replace('/homePage'); // 跳转到登录页或首页
}

此时再进行登录之后,tab数据任然存在页面上没有清空,但是浏览器存储已经被清空

此时可以想到状态存储的tab变量在登录之后未重新获取,而是保存之前的数据

总结

问题根因

  • 状态存储(Pinia)和会话存储(sessionStorage)未同步清空,导致 tab数据在内存中仍然存在。

解决方法

  • 在 Pinia Store 中新增 clearTab 函数,同时清空内存状态和会话存储。
  • 在退出登录时调用该清空函数,确保状态同步清空。

代码示例

  • Pinia Store 定义清空函数。
  • 在退出登录时调用clearTab ,同步状态和存储的清空操作。

效果

  • 每次退出登录后,tab状态和会话存储中的数据都会完全清空,重新登录后数据重新初始化。

到此这篇关于Vue 状态存储和会话存储同步清空问题解决方案的文章就介绍到这了,更多相关Vue 状态存储和会话存储同步清空问题解决方案内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue如何在style标签中使用变量(数据)详解

    vue如何在style标签中使用变量(数据)详解

    在我们编写css样式中是不能直接使用vue data中的变量的,下面这篇文章主要给大家介绍了关于vue如何在style标签中使用变量(数据)的相关资料,需要的朋友可以参考下
    2022-09-09
  • vue data有值,但是页面{{}} 取不到值的解决

    vue data有值,但是页面{{}} 取不到值的解决

    这篇文章主要介绍了vue data有值,但是页面{{}} 取不到值的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue配置文件自动生成路由和菜单实例代码

    vue配置文件自动生成路由和菜单实例代码

    因为不同的用户有不同的权限,能访问的页面是不一样的,所以我们在写后台管理系统时就会遇过这样的需求:根据后台数据动态添加路由和菜单,这篇文章主要给大家介绍了关于vue配置文件自动生成路由和菜单的相关资料,需要的朋友可以参考下
    2021-08-08
  • Vue实现简易翻页效果源码分享

    Vue实现简易翻页效果源码分享

    本文给大家分享了vue实现简易翻页效果,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-11-11
  • vue导出excel多层表头的实现方案详解

    vue导出excel多层表头的实现方案详解

    这篇文章主要为大家详细介绍了vue导出excel多层表头的实现方案,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以跟随小编一起学习一下
    2025-04-04
  • ant-design-vue 快速避坑指南(推荐)

    ant-design-vue 快速避坑指南(推荐)

    ant-design-vue是蚂蚁金服 Ant Design 官方唯一推荐的Vue版UI组件库,它其实是Ant Design的Vue实现,组件的风格与Ant Design保持同步,组件的html结构和css样式也保持一致,很多朋友在使用过程中遇到很多问题,今天小编就给大家分享一篇教程帮助大家快速闭坑,一起看看吧
    2020-01-01
  • vue3中使用highlight.js实现代码高亮显示的代码示例

    vue3中使用highlight.js实现代码高亮显示的代码示例

    代码高亮是在网页开发中常见的需求之一,它可以使代码在页面上以不同的颜色或样式进行突出显示提高可读性,这篇文章主要介绍了vue3中使用highlight.js实现代码高亮显示的相关资料,需要的朋友可以参考下
    2025-04-04
  • 详解vue-cli 脚手架 安装

    详解vue-cli 脚手架 安装

    这篇文章主要介绍了vue-cli脚手架安装,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • ElementUI日期选择器时间选择范围限制的实现

    ElementUI日期选择器时间选择范围限制的实现

    在日常开发中,我们会遇到一些情况,限制日期的范围的选择,本文就详细的介绍了ElementUI日期选择器时间选择范围限制的实现,文中通过示例代码介绍的非常详细,感兴趣的可以了解一下
    2022-04-04
  • vue框架实现将侧边栏完全隐藏

    vue框架实现将侧边栏完全隐藏

    这篇文章主要介绍了vue框架实现将侧边栏完全隐藏,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08

最新评论