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

Vue實現一個帶有緩存功能的Tab頁簽功能

 更新時間:2024年08月23日 10:38:46   作者:前端學步  
在現代?Web?應用中,Tab?頁簽功能是非常常見的一種交互模式,它可以幫助用戶在不同的視圖間快速切換,而不會丟失當前視圖的狀態(tài),本文將介紹如何在?Vue?項目中實現一個帶有緩存功能的?Tab?頁簽功能,需要的朋友可以參考下

概述

在現代 Web 應用中,Tab 頁簽功能是非常常見的一種交互模式。它可以幫助用戶在不同的視圖間快速切換,而不會丟失當前視圖的狀態(tài)。為了進一步提升用戶體驗,我們可以通過 keep-alive 組件來緩存已經打開的視圖,這樣即使用戶離開并再次回到這個視圖,也可以看到之前的狀態(tài)。

本文將介紹如何在 Vue 項目中實現一個帶有緩存功能的 Tab 頁簽功能。

效果實現

點擊左側菜單欄,添加tab頁及頁面緩存,關閉tab頁,刪除頁面緩存

功能實現(只展示核心代碼)

一、使用 keep-alive 緩存路由

為了實現頁面緩存,我們需要使用 keep-alive 組件。首先,在 App.vue 中引入 keep-alive 并

將其包裹在 <router-view> 外面。同時,我們可以使用 include 屬性來指定哪些組件應該被緩存。

<!-- 緩存路由 -->
<keep-alive :include="cacheViews">
    <router-view></router-view>
</keep-alive>

二、點擊左側菜單,添加頁簽并添加緩存標記

在左側菜單欄組件(例如 MenuTree.vue)中,我們需要監(jiān)聽用戶的點擊事件,以便在點擊某個菜單項時添加新的頁簽。同時,我們也需要將該組件的 name 添加到 cachedViews 數組中,以標記該組件應被緩存。請注意,這里的 name必須與頁面組件name、路由name保持一致。

// 點擊左側菜單時添加tab頁簽,添加緩存頁面
        const findIndex = this.existedTabs.findIndex(v => {
            return v.name == item.name
        })
        if(findIndex == -1) {
            // tab頁簽中不存在,push進去
            this.existedTabs.push(item);
            this.cacheViews.push(item.name)
        }
        this.$store.commit("saveTabsList", this.existedTabs); // 保存tab標簽頁
        this.$store.commit("saveCacheViews", this.cacheViews); // 保存需要緩存頁面組件

三、關閉頁簽,刪除緩存標記

在關閉頁簽時,我們需要從 cachedViews 數組中移除對應的組件名稱,以取消對該組件的緩存。

// 關閉tab頁簽時,刪除緩存標記
        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) {
        // 當前菜單,跳轉至后面/前面一個菜單
        if (findIndex < this.tabsListArray.length) {
          this.$router.push({
            name: this.tabsListArray[findIndex].name,
          });
        } else {
          this.$router.push({
            name: this.tabsListArray[findIndex - 1].name,
          });
        }
      }

總結來說,通過上述步驟,我們成功實現了動態(tài)添加菜單頁簽并緩存功能。在實際應用中,還需要考慮一些細節(jié),如處理未緩存頁面的刷新等。希望這篇文章能對您有所幫助!

到此這篇關于Vue實現一個帶有緩存的Tab頁簽功能的文章就介紹到這了,更多相關Vue實現Tab頁簽內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue實現骨架屏的示例代碼

    Vue實現骨架屏的示例代碼

    骨架屏就是在頁面數據尚未加載前先給用戶展示出頁面的大致結構。本文將利用Vue實現簡單的骨架屏,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-03-03
  • Vite3遷移Webpack5的實現

    Vite3遷移Webpack5的實現

    本文主要介紹了Vite3遷移Webpack5的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • vue3封裝Element導航菜單的實例代碼

    vue3封裝Element導航菜單的實例代碼

    這篇文章主要介紹了vue3封裝Element導航菜單的實例代碼,分為菜單數據格式示例,控制導航收縮的詳細代碼,本文通過實例代碼介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • 在vue中使用防抖和節(jié)流,防止重復點擊或重復上拉加載實例

    在vue中使用防抖和節(jié)流,防止重復點擊或重復上拉加載實例

    今天小編就為大家分享一篇在vue中使用防抖和節(jié)流,防止重復點擊或重復上拉加載實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Vue?實現新國標紅綠燈效果實例詳解

    Vue?實現新國標紅綠燈效果實例詳解

    這篇文章主要為大家介紹了Vue?實現新國標紅綠燈效果實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 基于Vue3自定義實現圖片翻轉預覽功能

    基于Vue3自定義實現圖片翻轉預覽功能

    這篇文章主要為大家詳細介紹了如何基于Vue3自定義實現簡單的圖片翻轉預覽功能,文中的示例代碼講解詳細,具有一定的學習價值,有需要的小伙伴可以參考一下
    2023-10-10
  • vue打包后,用后端接口報錯304、404問題

    vue打包后,用后端接口報錯304、404問題

    這篇文章主要介紹了vue打包后,用后端接口報錯304、404問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 關閉eslint檢查和ts檢查的簡單步驟記錄

    關閉eslint檢查和ts檢查的簡單步驟記錄

    這篇文章主要給大家介紹了關于關閉eslint檢查和ts檢查的相關資料,eslint是一個JavaScript的校驗插件,通常用來校驗語法或代碼的書寫風格,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-02-02
  • Vue在原窗口與新窗口打開外部鏈接的實現代碼

    Vue在原窗口與新窗口打開外部鏈接的實現代碼

    這篇文章主要介紹了Vue如何在原窗口與新窗口打開外部鏈接,文中給大家提到了vue跳轉外部鏈接的實現代碼,本文給大家介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Vue3使用vue-office插件實現word預覽功能

    Vue3使用vue-office插件實現word預覽功能

    vue-office是一個支持多種文件(docx、.xlsx、pdf)預覽的vue組件庫,支持vue2和vue3,這篇文章主要介紹了Vue3使用vue-office插件實現word預覽功能,需要的朋友可以參考下
    2024-04-04

最新評論