亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3緩存之路由緩存與Pinia狀態(tài)緩存詳解

 更新時(shí)間:2025年04月25日 09:55:34   作者:organwalk  
這篇文章主要介紹了Vue3緩存之路由緩存與Pinia狀態(tài)緩存,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Vue3緩存兩種:路由緩存與Pinia狀態(tài)緩存

單頁(yè)應(yīng)用中,最令人頭疼的就是頁(yè)面刷新或者回退時(shí),數(shù)據(jù)丟失或重新加載的問(wèn)題。

本文以微小demo介紹兩種緩存以應(yīng)付Vue3項(xiàng)目中的絕大多數(shù)需要緩存的業(yè)務(wù)。

路由緩存

一個(gè)令人頭疼的問(wèn)題是,當(dāng)路由后退或原地刷新時(shí),組件的生命周期會(huì)被重新觸發(fā),即可能導(dǎo)致生命周期鉤子中加載數(shù)據(jù)的函數(shù)被觸發(fā),為了避免這種情況,可以利用Vue-Router的路由緩存機(jī)制。

以一個(gè)文章列表為例,假設(shè)你點(diǎn)擊了一篇文章進(jìn)行閱讀,并希望返回時(shí)不要重載數(shù)據(jù)或觸發(fā)生命周期鉤子,你可以在router配置中,為文章列表頁(yè)面的meta選項(xiàng)加上keepAlive屬性,并設(shè)置為true:

{
        path : '/articleList',
        name : 'articleList',
        component: ()=>import('@/view/article/ArticleListView.vue'),
        meta: { keepAlive:true } // 此處添加
}

然后找到router-view組件,并對(duì)其進(jìn)行改寫(xiě):

 <router-view v-slot="{ Component }">
    <keep-alive>
      <component :is="Component"  v-if="$route.meta.keepAlive"/>
    </keep-alive>
    <component :is="Component"  v-if="!$route.meta.keepAlive"/>
  </router-view>

這樣就完成了對(duì)文章列表頁(yè)面的緩存。如果你需要為其他頁(yè)面進(jìn)行緩存,則可以按需為其路由配置keepAlive屬性

Pinia狀態(tài)緩存

一種場(chǎng)景是,我們有一行Type標(biāo)簽,點(diǎn)擊其可以加載不同分類下的文章列表,而這個(gè)Type會(huì)被我們納入狀態(tài)管理。

一個(gè)尷尬的事實(shí)是,當(dāng)頁(yè)面刷新或者路由回退時(shí),Type也隨之被重置,丟失了原來(lái)的狀態(tài)。為此,可以使用Pinia的額外插件,實(shí)現(xiàn)其緩存:

npm i pinia-plugin-persist --save

安裝完成后,在main.js文件中,進(jìn)行如下配置:

import { createPinia } from 'pinia'
import piniaPluginPersist from 'pinia-plugin-persist' // 注意此處

const pinia = createPinia()
pinia.use(piniaPluginPersist)  // 注意此處

const app = createApp(App)
app.use(pinia)

然后回到我們的store.js中進(jìn)行配置,假設(shè)針對(duì)Type進(jìn)行狀態(tài)管理并緩存,可以配置其persist選項(xiàng)下的enabled屬性為true:

export const useNowTypeStore = defineStore('nowType', () => {
        const nowType = ref(0)

        function setNowType(realType) {
            nowType.value = realType
        }

        return {nowType, setNowType}
    }, {
        persist: {
            enabled: true
        }
    } // 注意此處
)

這樣就完成了對(duì)NowType的緩存。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 解決vue無(wú)法設(shè)置滾動(dòng)位置的問(wèn)題

    解決vue無(wú)法設(shè)置滾動(dòng)位置的問(wèn)題

    這篇文章主要介紹了解決vue無(wú)法設(shè)置滾動(dòng)位置的問(wèn)題 ,需要的朋友可以參考下
    2018-10-10
  • element-ui 中的table的列隱藏問(wèn)題解決

    element-ui 中的table的列隱藏問(wèn)題解決

    這篇文章主要介紹了element-ui 中的table的列隱藏問(wèn)題解決,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • Vue3?函數(shù)式彈窗的實(shí)例小結(jié)

    Vue3?函數(shù)式彈窗的實(shí)例小結(jié)

    這篇文章主要介紹了Vue3?函數(shù)式彈窗的實(shí)例小結(jié),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-11-11
  • vue2和vue3子組件父組件之間的傳值方法

    vue2和vue3子組件父組件之間的傳值方法

    在組件化開(kāi)發(fā)的過(guò)程中難免會(huì)遇見(jiàn)子組件和父組件之間的通訊那么這里講關(guān)于vue2和vue3不同的通訊方式,文中有詳細(xì)的代碼示例供大家參考,感興趣的同學(xué)可以閱讀下
    2023-05-05
  • 一次vue項(xiàng)目?jī)?yōu)化的實(shí)際操作記錄

    一次vue項(xiàng)目?jī)?yōu)化的實(shí)際操作記錄

    用vue開(kāi)發(fā)項(xiàng)目上線以后,發(fā)現(xiàn)首頁(yè)加載速度非常慢,如果項(xiàng)目比較大,甚至可能出現(xiàn)10s以上的等待,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目?jī)?yōu)化的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • 如何用Vue3切換中英文顯示舉例說(shuō)明

    如何用Vue3切換中英文顯示舉例說(shuō)明

    這篇文章主要給大家介紹了關(guān)于如何用Vue3切換中英文顯示的相關(guān)資料,在Vue3中使用vue-i18n進(jìn)行國(guó)際化設(shè)置,包括安裝、配置、在組件中使用$t方法獲取翻譯字符串,以及可選的動(dòng)態(tài)加載語(yǔ)言包以提高性能,需要的朋友可以參考下
    2024-11-11
  • 解決VUE雙向綁定失效的問(wèn)題

    解決VUE雙向綁定失效的問(wèn)題

    今天小編就為大家分享一篇解決VUE雙向綁定失效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • vue使用Vue.extend創(chuàng)建全局toast組件實(shí)例

    vue使用Vue.extend創(chuàng)建全局toast組件實(shí)例

    這篇文章主要介紹了vue使用Vue.extend創(chuàng)建全局toast組件實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • 前端vue3?setup使用教程

    前端vue3?setup使用教程

    這篇文章主要為大家介紹了前端vue3架構(gòu)setup使用教程,詳細(xì)介紹?setup?的用法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-02-02
  • vue實(shí)現(xiàn)登錄功能

    vue實(shí)現(xiàn)登錄功能

    這篇文章主要介紹了vue實(shí)現(xiàn)登錄功能的步驟,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12

最新評(píng)論