Vue實(shí)現(xiàn)一個(gè)帶有緩存功能的Tab頁(yè)簽功能
概述
在現(xiàn)代 Web 應(yīng)用中,Tab 頁(yè)簽功能是非常常見(jiàn)的一種交互模式。它可以幫助用戶在不同的視圖間快速切換,而不會(huì)丟失當(dāng)前視圖的狀態(tài)。為了進(jìn)一步提升用戶體驗(yàn),我們可以通過(guò) keep-alive 組件來(lái)緩存已經(jīng)打開(kāi)的視圖,這樣即使用戶離開(kāi)并再次回到這個(gè)視圖,也可以看到之前的狀態(tài)。
本文將介紹如何在 Vue 項(xiàng)目中實(shí)現(xiàn)一個(gè)帶有緩存功能的 Tab 頁(yè)簽功能。
效果實(shí)現(xiàn)
點(diǎn)擊左側(cè)菜單欄,添加tab頁(yè)及頁(yè)面緩存,關(guān)閉tab頁(yè),刪除頁(yè)面緩存
功能實(shí)現(xiàn)(只展示核心代碼)
一、使用 keep-alive 緩存路由
為了實(shí)現(xiàn)頁(yè)面緩存,我們需要使用 keep-alive 組件。首先,在 App.vue 中引入 keep-alive 并
將其包裹在 <router-view> 外面。同時(shí),我們可以使用 include 屬性來(lái)指定哪些組件應(yīng)該被緩存。
<!-- 緩存路由 --> <keep-alive :include="cacheViews"> <router-view></router-view> </keep-alive>
二、點(diǎn)擊左側(cè)菜單,添加頁(yè)簽并添加緩存標(biāo)記
在左側(cè)菜單欄組件(例如 MenuTree.vue)中,我們需要監(jiān)聽(tīng)用戶的點(diǎn)擊事件,以便在點(diǎn)擊某個(gè)菜單項(xiàng)時(shí)添加新的頁(yè)簽。同時(shí),我們也需要將該組件的 name 添加到 cachedViews 數(shù)組中,以標(biāo)記該組件應(yīng)被緩存。請(qǐng)注意,這里的 name必須與頁(yè)面組件name、路由name保持一致。
// 點(diǎn)擊左側(cè)菜單時(shí)添加tab頁(yè)簽,添加緩存頁(yè)面 const findIndex = this.existedTabs.findIndex(v => { return v.name == item.name }) if(findIndex == -1) { // tab頁(yè)簽中不存在,push進(jìn)去 this.existedTabs.push(item); this.cacheViews.push(item.name) } this.$store.commit("saveTabsList", this.existedTabs); // 保存tab標(biāo)簽頁(yè) this.$store.commit("saveCacheViews", this.cacheViews); // 保存需要緩存頁(yè)面組件
三、關(guān)閉頁(yè)簽,刪除緩存標(biāo)記
在關(guān)閉頁(yè)簽時(shí),我們需要從 cachedViews
數(shù)組中移除對(duì)應(yīng)的組件名稱,以取消對(duì)該組件的緩存。
// 關(guān)閉tab頁(yè)簽時(shí),刪除緩存標(biāo)記 const findIndex = this.tabsListArray.findIndex((v) => { return v.name == targetName; }); if (findIndex > -1) { this.tabsListArray.splice(findIndex, 1); const findIndexCacheViews = this.cacheViews.indexOf(targetName); if (findIndexCacheViews > -1) { this.cacheViews.splice(findIndex, 1); } } this.$store.commit("saveTabsList", this.tabsListArray); this.$store.commit("saveCacheViews", this.cacheViews); if (targetName == this.activename) { // 當(dāng)前菜單,跳轉(zhuǎn)至后面/前面一個(gè)菜單 if (findIndex < this.tabsListArray.length) { this.$router.push({ name: this.tabsListArray[findIndex].name, }); } else { this.$router.push({ name: this.tabsListArray[findIndex - 1].name, }); } }
總結(jié)來(lái)說(shuō),通過(guò)上述步驟,我們成功實(shí)現(xiàn)了動(dòng)態(tài)添加菜單頁(yè)簽并緩存功能。在實(shí)際應(yīng)用中,還需要考慮一些細(xì)節(jié),如處理未緩存頁(yè)面的刷新等。希望這篇文章能對(duì)您有所幫助!
到此這篇關(guān)于Vue實(shí)現(xiàn)一個(gè)帶有緩存的Tab頁(yè)簽功能的文章就介紹到這了,更多相關(guān)Vue實(shí)現(xiàn)Tab頁(yè)簽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3封裝Element導(dǎo)航菜單的實(shí)例代碼
這篇文章主要介紹了vue3封裝Element導(dǎo)航菜單的實(shí)例代碼,分為菜單數(shù)據(jù)格式示例,控制導(dǎo)航收縮的詳細(xì)代碼,本文通過(guò)實(shí)例代碼介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-03-03在vue中使用防抖和節(jié)流,防止重復(fù)點(diǎn)擊或重復(fù)上拉加載實(shí)例
今天小編就為大家分享一篇在vue中使用防抖和節(jié)流,防止重復(fù)點(diǎn)擊或重復(fù)上拉加載實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11Vue?實(shí)現(xiàn)新國(guó)標(biāo)紅綠燈效果實(shí)例詳解
這篇文章主要為大家介紹了Vue?實(shí)現(xiàn)新國(guó)標(biāo)紅綠燈效果實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08基于Vue3自定義實(shí)現(xiàn)圖片翻轉(zhuǎn)預(yù)覽功能
這篇文章主要為大家詳細(xì)介紹了如何基于Vue3自定義實(shí)現(xiàn)簡(jiǎn)單的圖片翻轉(zhuǎn)預(yù)覽功能,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,有需要的小伙伴可以參考一下2023-10-10vue打包后,用后端接口報(bào)錯(cuò)304、404問(wèn)題
這篇文章主要介紹了vue打包后,用后端接口報(bào)錯(cuò)304、404問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05關(guān)閉eslint檢查和ts檢查的簡(jiǎn)單步驟記錄
這篇文章主要給大家介紹了關(guān)于關(guān)閉eslint檢查和ts檢查的相關(guān)資料,eslint是一個(gè)JavaScript的校驗(yàn)插件,通常用來(lái)校驗(yàn)語(yǔ)法或代碼的書寫風(fēng)格,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02Vue在原窗口與新窗口打開(kāi)外部鏈接的實(shí)現(xiàn)代碼
這篇文章主要介紹了Vue如何在原窗口與新窗口打開(kāi)外部鏈接,文中給大家提到了vue跳轉(zhuǎn)外部鏈接的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02Vue3使用vue-office插件實(shí)現(xiàn)word預(yù)覽功能
vue-office是一個(gè)支持多種文件(docx、.xlsx、pdf)預(yù)覽的vue組件庫(kù),支持vue2和vue3,這篇文章主要介紹了Vue3使用vue-office插件實(shí)現(xiàn)word預(yù)覽功能,需要的朋友可以參考下2024-04-04