vue3實現跨頁面緩存

避免頻繁向后端發送請求,vue3中,可以用緩存機制,為了實現跨頁面緩存,可以把緩存放到localsotrage里面

關鍵代碼:

const globalCache = JSON.parse(localStorage.getItem('globalCache')) || {};

然后加一個forceRefresh關鍵字,

const fetchData = async (forceRefresh = false) => {

? ? const cacheKey = `${userId.value}-${currentPage.value}-${pageSize.value}`;

? ? if (!forceRefresh && globalCache[cacheKey]) {

? ? ? ? myStores.value = globalCache[cacheKey].data;

? ? ? ? totalCount.value = globalCache[cacheKey].total_count;

? ? ? ? return;

? ? }

讓緩存從globalCache里面取,
完整代碼:
?

<template><!-- 清空緩存按鈕 --><router-link to="/home" custom v-slot="{ navigate }"><van-button type="default" @click="// 清空全局緩存對象的所有屬性Object.keys(globalCache).forEach(key => delete globalCache[key]);// 強制刷新數據(跳過緩存)fetchData(true);navigate();" size="small">打卡店鋪</van-button></router-link>
</template><script setup>
// 緩存系統核心實現
// ------------------------------------------------------------------
// 初始化全局緩存:從 localStorage 加載已有緩存或創建空對象
const globalCache = JSON.parse(localStorage.getItem('globalCache')) || {};// 緩存更新方法
const updateCache = (cacheKey, data) => {// 將新數據存入緩存對象globalCache[cacheKey] = data;// 同步更新到 localStorage 持久化存儲localStorage.setItem('globalCache', JSON.stringify(globalCache));
};// 清空緩存方法
const clearCache = () => {// 遍歷刪除緩存對象所有屬性Object.keys(globalCache).forEach(key => delete globalCache[key]);// 清除 localStorage 中的持久化存儲localStorage.removeItem('globalCache');
};// 數據獲取邏輯(帶緩存機制)
const fetchData = async (forceRefresh = false) => {// 生成當前請求的緩存鍵(用戶ID+分頁參數)const cacheKey = `${userId.value}-${currentPage.value}-${pageSize.value}`;// 緩存命中邏輯(當非強制刷新且存在有效緩存時)if (!forceRefresh && globalCache[cacheKey]) {// 從緩存讀取數據myStores.value = globalCache[cacheKey].data;totalCount.value = globalCache[cacheKey].total_count;return;}// 無有效緩存時發起網絡請求const response = await axios.get(`${baseURL}/query_store/${userId.value}?page=${currentPage.value}&pageSize=${pageSize.value}`);// 更新響應數據到緩存系統updateCache(cacheKey, {data: response.data.data,total_count: response.data.total_count,});
};// 路由導航守衛(控制頁面離開時的緩存清理)
onBeforeRouteLeave((to, from, next) => {// 僅當跳轉到信息填報頁面時保留緩存if (to.name === 'informationFill') {next();} else {// 其他路由跳轉時清空緩存clearCache();next();}
});
</script>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/72113.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/72113.shtml
英文地址,請注明出處:http://en.pswp.cn/web/72113.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c++類和對象(下篇)上

今天又重新回到c的學習中~在前兩篇博客中,我簡單的學習了類的定義,實例化,以及類中的默認成員函數.下篇是類和對象的收尾篇,在這篇中我將補充一下中篇所講的構造函數以及介紹一些類和對象的新知識.下面讓我們開始學習吧. 再談構造函數 在之前我們實現構造函數時,初始化成員變量…

深度學習 bert流程

Token IDs 在自然語言處理任務中&#xff0c;特別是使用預訓練模型如BERT時&#xff0c;文本首先通過一個分詞器&#xff08;例如 BertTokenizer&#xff09;轉換為一系列的token IDs。這些ID是每個詞或子詞單元在詞匯表&#xff08;包含漢字、英文單詞、標點符號&#xff09;…

PPT內視頻播放無法播放的原因及解決辦法

PPT內視頻無法播放&#xff0c;通常是視頻編解碼的問題。目前我遇到的常見的視頻編碼格式有H.264&#xff0c;H.265&#xff0c;VP9&#xff0c;AV1這4種。H.264編解碼的視頻&#xff0c;Windows原生系統可以直接播放&#xff0c;其他的視頻編碼格式需要安裝對應的視頻編解碼插…

星越L_行李艙空間拓展講解

目錄 1.儲物槽 2.底板蓋儲物空間 3.掛鉤 3.左側照明燈 4.第二排座椅放倒 1.儲物槽 使用鑰匙或者后備箱按鈕打開電動后備箱,左側儲物槽可儲藏物品。 2.底板蓋儲物空間 打開地板蓋,下方有儲物空間。并放置了隨車工具。 3.掛鉤 后備箱左右兩測各有一個掛鉤。

深度學習與大模型-矩陣

矩陣其實在我們的生活中也有很多應用&#xff0c;只是我們沒注意罷了。 1. 矩陣是什么&#xff1f; 簡單來說&#xff0c;矩陣就是一個長方形的數字表格。比如你有一個2行3列的矩陣&#xff0c;可以寫成這樣&#xff1a; 這個矩陣有2行3列&#xff0c;每個數字都有一個位置&a…

LuaJIT 學習(2)—— 使用 FFI 庫的幾個例子

文章目錄 介紹Motivating Example: Calling External C Functions例子&#xff1a;Lua 中調用 C 函數 Motivating Example: Using C Data StructuresAccessing Standard System FunctionsAccessing the zlib Compression LibraryDefining Metamethods for a C Type例子&#xf…

基于 FastText、dlib 和 CppJieba 的中文語義相似度計算實踐

在自然語言處理(NLP)領域,語義相似度計算是許多任務的核心,例如問答系統、文本檢索和推薦系統。然而,中文因缺乏顯式分詞和復雜的語義結構,實現高效的語義對比具有一定挑戰性。 本文將介紹如何結合 CppJieba(高效中文分詞工具)、FastText(詞向量模型)和 dlib(機器學…

HCIA-11.以太網鏈路聚合與交換機堆疊、集群

鏈路聚合背景 拓撲組網時為了高可用&#xff0c;需要網絡的冗余備份。但增加冗余容易后會出現環路&#xff0c;所以我們部署了STP協議來破除環路。 但是&#xff0c;根據實際業務的需要&#xff0c;為網絡不停的增加冗余是現實需要的一部分。 那么&#xff0c;為了讓網絡冗余…

Unity基于C#+UGUI解決方案,制作每日簽到系統(本地存儲簽到數據)

一、需求介紹:基于本地存儲系統制作一個每日簽到系統界面,相關簽到界面如下圖所示,點擊“簽到有禮”按鈕后就會跳轉到“每日登錄禮”這個界面,點擊“立即簽到”按鈕之后,按鈕就會置灰,而且按鈕的文字會變成“等待明日”。 二、制作界面顯示相關功能,需要在Unity中新建一…

AI本地部署

文檔加載&#xff08;Document Loading&#xff09;&#xff1a;從多種不同來源加載文檔。LangChain提供了100多種不同的文檔加載器&#xff0c;包括PDF在內的非結構化的數據、SQL在內的結構化的數據&#xff0c;以及Python、Java之類的代碼等? ?文本分割&#xff08;Splitti…

精準車型識別:視覺分析技術的力量

隨著智慧城市和智能交通系統的快速發展&#xff0c;車型識別檢測成為交通管理、安全監控和數據分析的關鍵技術之一。利用視覺分析的方式&#xff0c;我們可以高效、準確地檢測監控下的車輛類型、車牌信息及車流量&#xff0c;為城市交通管理提供有力支持。本文將從背景、技術實…

上下文微調(Contextual Fine-Tuning, CFT)提高大型語言模型(LLMs)在特定領域的學習和推理能力

大型語言模型(LLMs)在開放領域任務中表現出色,但在快速演變的專業領域(如醫學、金融)中面臨挑戰: 知識更新難題:傳統指令微調(Instruction Fine-Tuning, IFT)依賴顯式指令,難以適應動態知識。災難性遺忘:持續預訓練(Continued Pretraining, CPT)可能導致模型遺忘已…

在 LaTeX 中強制表格位于頁面頂部

在 LaTeX 中強制表格位于頁面頂部&#xff0c;可以通過以下 多種方法結合使用&#xff0c;按優先級推薦&#xff1a; 方法 1&#xff1a;使用 [!t] 位置限定符 原理&#xff1a;通過 [!t] 強制 LaTeX 優先將表格放置在頁面頂部&#xff08;Top&#xff09;&#xff0c;! 表示忽…

kotlin與MVVM的結合使用總結(二)

在 MVVM&#xff08;Model - View - ViewModel&#xff09;架構中&#xff0c;M 層即 Model 層&#xff0c;主要負責數據的管理、存儲和獲取&#xff0c;它與業務邏輯和數據處理相關。在 Kotlin 中實現 MVVM 的 M 層&#xff0c;通常會涉及數據類的定義、數據的本地存儲與遠程獲…

電子元器件選型與實戰應用—16 怎么選一個合適的MCU芯片?

文章目錄 1. 選型要素1.1 價格1.2 技術支持1.3 廠家優勢1.4 功耗1.5 特殊功能1.6 統計外設1.7 確定外設占用的內存和flash大小1.8 確定外設通信接口1.9 確定外設通信接口的電平1.10 確定外設的GPIO數量1.11 確定外設的供電和功耗1.12 確定外設GPIO的種類1.13 確定ADC的數量1.14…

VSCode 搭建C++編程環境 2025新版圖文安裝教程(100%搭建成功,VSCode安裝+C++環境搭建+運行測試+背景圖設置)

名人說&#xff1a;博觀而約取&#xff0c;厚積而薄發。——蘇軾《稼說送張琥》 創作者&#xff1a;Code_流蘇(CSDN)&#xff08;一個喜歡古詩詞和編程的Coder&#x1f60a;&#xff09; 目錄 一、VScode下載及安裝二、安裝 MinGW-w64 工具鏈三、Windows環境變量配置四、檢查 M…

Django系列教程(7)——路由配置URLConf

目錄 URLconf是如何工作的? path和re_path方法 更多URL配置示例 URL的命名及reverse()方法 使用命名URL 硬編碼URL - 不建議 URL指向基于類的視圖(View) 通過URL傳遞額外的參數 小結 Django的項目文件夾和每個應用(app)目錄下都有urls.py文件&#xff0c;它們構成了D…

transformer bert 多頭自注意力

輸入的&#xff08;a1,a2,a3,a4&#xff09;是最終嵌入&#xff0c;是一個(512,768)的矩陣&#xff1b;而a1是一個token&#xff0c;尺寸是768 a1通過wq權重矩陣&#xff0c;經過全連接變換得到查詢向量q1&#xff1b;a2通過Wk權重矩陣得到鍵向量k2&#xff1b;q和k點乘就是值…

Spring Boot + MyBatis-Plus 項目目錄結構

以下是一個標準的 Spring Boot MyBatis-Plus 項目目錄結構及文件命名規范&#xff0c;包含每個目錄和文件的作用說明&#xff0c;適用于中大型項目開發&#xff1a; 項目根目錄結構 src/ ├── main/ │ ├── java/ # Java 源代碼 │ │ └── com/…

Webpack優化前端性能

Webpack優化前端性能☆☆ 涵蓋了代碼分割、懶加載、壓縮、緩存優化、Tree Shaking、圖片優化、CDN使用等多個方面。 Webpack優化前端性能詳解(2025綜合實踐版) Webpack作為現代前端工程化的核心工具,其優化能力直接影響項目的首屏速度、交互流暢度和用戶體驗。以下從代碼維…