欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue?狀態(tài)存儲和會話存儲同步清空問題解決方案(最新推薦)

 更新時間:2024年12月16日 14:33:15   作者:前端糕手  
文章介紹了在使用Pinia定義的useHeaderTabStore中,tab狀態(tài)通過會話存儲初始化但未在退出登錄時同步清空的問題,通過在PiniaStore中定義清空tab的函數(shù),并在退出登錄時調(diào)用該函數(shù),可以確保狀態(tài)和會話存儲同步清空,避免內(nèi)存中殘留舊數(shù)據(jù),感興趣的朋友一起看看吧

問題描述:

   在使用 Pinia 定義的 useHeaderTabStore中,tab狀態(tài)是通過會話存儲(sessionStorage)初始化的。然而在退出登錄時,即使清空了會話存儲中的 tab數(shù)據(jù),重新登錄后頁面上的 tab數(shù)據(jù)仍然存在,這是因為 Pinia 狀態(tài)在內(nèi)存中仍然保留了之前的數(shù)據(jù),未重新獲取會話存儲的數(shù)據(jù)。

解決方法:

  • 在 Pinia Store 中定義一個清空 tab 的函數(shù)

    • 清空內(nèi)存中 tab的狀態(tài)變量。
    • 同時清空會話存儲中的 tab數(shù)據(jù)。
  • 在退出登錄函數(shù)中調(diào)用該清空函數(shù)

    • 這樣可以確保狀態(tài)和會話存儲同步清空

狀態(tài)存儲文件:

const useHeaderTabStore=defineStore('headerTab',{
state:():any=>({
tab:sessionStorage.getItem('tab')?JSON.parse(sessionStorage.getItem('tab')||'{}'): [],
currentTab:{}
}),
getters:{
  getTab():any[]{
return this.tab
  }
},
actions:{
//添加的清除tab的函數(shù)
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

退出登錄函數(shù)

//一開始的問題函數(shù)
  function logout() {
  router.replace('/homePage');
 sessionStorage.removeItem('tab');
}
//修改成調(diào)用清除函數(shù)
function logout() {
  const headerTabStore = useHeaderTabStore(); // 引用 Pinia Store
  headerTabStore.clearTab(); // 調(diào)用清空函數(shù)
  router.replace('/homePage'); // 跳轉到登錄頁或首頁
}

此時再進行登錄之后,tab數(shù)據(jù)任然存在頁面上沒有清空,但是瀏覽器存儲已經(jīng)被清空

此時可以想到狀態(tài)存儲的tab變量在登錄之后未重新獲取,而是保存之前的數(shù)據(jù)

總結

問題根因

  • 狀態(tài)存儲(Pinia)和會話存儲(sessionStorage)未同步清空,導致 tab數(shù)據(jù)在內(nèi)存中仍然存在。

解決方法

  • 在 Pinia Store 中新增 clearTab 函數(shù),同時清空內(nèi)存狀態(tài)和會話存儲。
  • 在退出登錄時調(diào)用該清空函數(shù),確保狀態(tài)同步清空。

代碼示例

  • Pinia Store 定義清空函數(shù)。
  • 在退出登錄時調(diào)用clearTab ,同步狀態(tài)和存儲的清空操作。

效果

  • 每次退出登錄后,tab狀態(tài)和會話存儲中的數(shù)據(jù)都會完全清空,重新登錄后數(shù)據(jù)重新初始化。

到此這篇關于Vue 狀態(tài)存儲和會話存儲同步清空問題解決方案的文章就介紹到這了,更多相關Vue 狀態(tài)存儲和會話存儲同步清空問題解決方案內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue如何在style標簽中使用變量(數(shù)據(jù))詳解

    vue如何在style標簽中使用變量(數(shù)據(jù))詳解

    在我們編寫css樣式中是不能直接使用vue data中的變量的,下面這篇文章主要給大家介紹了關于vue如何在style標簽中使用變量(數(shù)據(jù))的相關資料,需要的朋友可以參考下
    2022-09-09
  • vue data有值,但是頁面{{}} 取不到值的解決

    vue data有值,但是頁面{{}} 取不到值的解決

    這篇文章主要介紹了vue data有值,但是頁面{{}} 取不到值的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue配置文件自動生成路由和菜單實例代碼

    vue配置文件自動生成路由和菜單實例代碼

    因為不同的用戶有不同的權限,能訪問的頁面是不一樣的,所以我們在寫后臺管理系統(tǒng)時就會遇過這樣的需求:根據(jù)后臺數(shù)據(jù)動態(tài)添加路由和菜單,這篇文章主要給大家介紹了關于vue配置文件自動生成路由和菜單的相關資料,需要的朋友可以參考下
    2021-08-08
  • Vue實現(xiàn)簡易翻頁效果源碼分享

    Vue實現(xiàn)簡易翻頁效果源碼分享

    本文給大家分享了vue實現(xiàn)簡易翻頁效果,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-11-11
  • vue導出excel多層表頭的實現(xiàn)方案詳解

    vue導出excel多層表頭的實現(xiàn)方案詳解

    這篇文章主要為大家詳細介紹了vue導出excel多層表頭的實現(xiàn)方案,文中的示例代碼簡潔易懂,具有一定的借鑒價值,有需要的小伙伴可以跟隨小編一起學習一下
    2025-04-04
  • ant-design-vue 快速避坑指南(推薦)

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

    ant-design-vue是螞蟻金服 Ant Design 官方唯一推薦的Vue版UI組件庫,它其實是Ant Design的Vue實現(xiàn),組件的風格與Ant Design保持同步,組件的html結構和css樣式也保持一致,很多朋友在使用過程中遇到很多問題,今天小編就給大家分享一篇教程幫助大家快速閉坑,一起看看吧
    2020-01-01
  • vue3中使用highlight.js實現(xiàn)代碼高亮顯示的代碼示例

    vue3中使用highlight.js實現(xiàn)代碼高亮顯示的代碼示例

    代碼高亮是在網(wǎng)頁開發(fā)中常見的需求之一,它可以使代碼在頁面上以不同的顏色或樣式進行突出顯示提高可讀性,這篇文章主要介紹了vue3中使用highlight.js實現(xiàn)代碼高亮顯示的相關資料,需要的朋友可以參考下
    2025-04-04
  • 詳解vue-cli 腳手架 安裝

    詳解vue-cli 腳手架 安裝

    這篇文章主要介紹了vue-cli腳手架安裝,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • ElementUI日期選擇器時間選擇范圍限制的實現(xiàn)

    ElementUI日期選擇器時間選擇范圍限制的實現(xiàn)

    在日常開發(fā)中,我們會遇到一些情況,限制日期的范圍的選擇,本文就詳細的介紹了ElementUI日期選擇器時間選擇范圍限制的實現(xiàn),文中通過示例代碼介紹的非常詳細,感興趣的可以了解一下
    2022-04-04
  • vue框架實現(xiàn)將側邊欄完全隱藏

    vue框架實現(xiàn)將側邊欄完全隱藏

    這篇文章主要介紹了vue框架實現(xiàn)將側邊欄完全隱藏,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論