目錄
2、路由獨享守衛" >2、路由獨享守衛
3、局部守衛" >3、局部守衛
首頁 web前端 前端問答 vue的導航鉤子有哪幾個

vue的導航鉤子有哪幾個

Dec 15, 2022 am 10:59 AM
vue 導航鉤子

vue的導覽鉤子有3種:1、全域守衛鉤子,是指路由範例上直接操作的鉤子函數,特點是所有路由配置的元件都會觸發。 2.路由獨享守衛鉤子,是指在單一路由配置的時候也可以設定的鉤子函數,且只能在這個路由下運作。 3.局部守衛鉤子,是指在元件內執行的鉤子函數,類似於陣列內的生命週期函數,相當於為配置路由的元件添加的生命週期鉤子函數。

vue的導航鉤子有哪幾個

本教學操作環境:windows7系統、vue3版,DELL G3電腦。

導航鉤子的作用

  • #vue-router提供的導航鉤子主要用來攔截導航,讓它完成跳轉或取消。

導航鉤子的分類

  • 全域守衛
  • 路由獨享受守衛
  • 局部守衛

#1、全域守衛

是指在路由範例上直接操作的鉤子函數,特點是所有路由配置的元件都會觸發。簡單點說就是觸發路由就會觸發這些鉤子函數。鉤子函數執行順序包括beforeEach、beforeResolve、afterEach三個。

<strong>[beforeEach]</strong>:在路由跳轉前觸發,參數包括to,from,next三個,這個鉤子作用主要是用於登入驗證,也就是路由還沒跳轉提前告知,以免跳轉了再通知就為時已晚。

 router.beforeEach  router.beforeResolve  router.afterEach
    const router = new VueRouter({ ... });
    router.beforeEach((to, from, next) => {
        // do someting
    });
登入後複製
  • to:代表要進入的目標,它是一個路由物件
  • from:代表目前正要離開的路由,同樣也是一個路由物件
  • next:這是一個必須需要呼叫的方法,而具體的執行效果則依賴next方法呼叫的參數

<strong>[beforeResolve]</strong> :這個鉤子和beforeEach類似,也是路由跳轉前觸發,參數也是to,from,next三個,和beforeEach區別官方解釋為:

 區別是在導航被確認之前,同時在所有元件內守衛和非同步路由元件被解析之後,解析守衛就會被呼叫。

即在beforeEach和元件內beforeRouteEnter之後,afterEach之後,afterEach之前呼叫。

<strong>[afterEach]</strong>:和beforeEach相反,它是在路由跳轉完成之後觸發,參數包括to、from,沒有了next,它發生在beforeEach和beforeResolve之後,beforeRouteEnter(足跡按內守衛)之前。

 const router = new VueRouter({ ... });
    router.beforeEach((to, from, next) => {
        // do someting
    });
  //全局后置钩子,后置钩子并没有 next 函数,也不会改变导航本身
    router.afterEach((to, from) => {
        // do someting
    });
登入後複製

2、路由獨享守衛

是指在單一路由配置的時候也可以設定的鉤子函數,並且只能在這個路由下運作。其位置如下,也就是像File這樣的元件都存在這樣的鉤子函數。目前它只有一個鉤子函數beforeEnter。

[beforeEnter]#:和beforeEach完全相同,如果都設定則在beforeEach之後緊接著執行,參數有to、from、 next。

  cont router = new VueRouter({
        routes: [
            {
                path: &#39;/file&#39;,
                component: File,
                beforeEnter: (to, from ,next) => {
                    // do someting
                }
            }
        ]
    });
登入後複製

3、局部守衛

#是指在元件內執行的鉤子函數,類似陣列內的生命週期函數,相當於為配置路由的元件新增的生命週期鉤子函數。鉤子函數依執行順序包括beforeRouteEnter、beforeRouteUpdate(2.2新增)、beforeRouteLeave三個,執行位置如下:

 const File = {
        template: `<div>This is file</div>`,
        beforeRouteEnter(to, from, next) {
            // do someting
            // 在渲染该组件的对应路由被 confirm 前调用
        },
        beforeRouteUpdate(to, from, next) {
            // do someting
            // 在当前路由改变,但是依然渲染该组件是调用
        },
        beforeRouteLeave(to, from ,next) {
            // do someting
            // 导航离开该组件的对应路由时被调用
        }
    }
登入後複製

#路由跳轉導航流程,當由A路由–>B路由的時候

1、在A元件裡呼叫離開守衛。 A元件中的beforeRouterLeave

2、呼叫全域的beforeEach守衛。 router.beforeEach

3、再執行B路由配置裡呼叫beforeEnter。

routes:[
      {
          path:&#39;/b&#39;,
          component:B,
          beforeEnter:(to,form,next)=>{
             ..... 
          }
      }
  ]
登入後複製

4、再執行B元件的進入守衛。 B元件中beforeRouterEnter

5、呼叫全域的beforeResolve守衛(2.5 )。 router.beforeResolve

6、導航被確認。

7、呼叫全域的afterEach鉤子。 router.afterEach

8、觸發DOM更新。

【相關推薦:vuejs影片教學web前端開發

以上是vue的導航鉤子有哪幾個的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

vue怎麼給按鈕添加函數 vue怎麼給按鈕添加函數 Apr 08, 2025 am 08:51 AM

可以通過以下步驟為 Vue 按鈕添加函數:將 HTML 模板中的按鈕綁定到一個方法。在 Vue 實例中定義該方法並編寫函數邏輯。

vue中怎麼用bootstrap vue中怎麼用bootstrap Apr 07, 2025 pm 11:33 PM

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

vue.js怎麼引用js文件 vue.js怎麼引用js文件 Apr 07, 2025 pm 11:27 PM

在 Vue.js 中引用 JS 文件的方法有三種:直接使用 &lt;script&gt; 標籤指定路徑;利用 mounted() 生命週期鉤子動態導入;通過 Vuex 狀態管理庫進行導入。

vue中的watch怎麼用 vue中的watch怎麼用 Apr 07, 2025 pm 11:36 PM

Vue.js 中的 watch 選項允許開發者監聽特定數據的變化。當數據發生變化時,watch 會觸發一個回調函數,用於執行更新視圖或其他任務。其配置選項包括 immediate,用於指定是否立即執行回調,以及 deep,用於指定是否遞歸監聽對像或數組的更改。

vue返回上一頁的方法 vue返回上一頁的方法 Apr 07, 2025 pm 11:30 PM

Vue.js 返回上一頁有四種方法:$router.go(-1)$router.back()使用 &lt;router-link to=&quot;/&quot;&gt; 組件window.history.back(),方法選擇取決於場景。

vue多頁面開發是啥意思 vue多頁面開發是啥意思 Apr 07, 2025 pm 11:57 PM

Vue 多頁面開發是一種使用 Vue.js 框架構建應用程序的方法,其中應用程序被劃分為獨立的頁面:代碼維護性:將應用程序拆分為多個頁面可以使代碼更易於管理和維護。模塊化:每個頁面都可以作為獨立的模塊,便於重用和替換。路由簡單:頁面之間的導航可以通過簡單的路由配置來管理。 SEO 優化:每個頁面都有自己的 URL,這有助於搜索引擎優化。

怎樣查詢vue的版本 怎樣查詢vue的版本 Apr 07, 2025 pm 11:24 PM

可以通過以下方法查詢 Vue 版本:使用 Vue Devtools 在瀏覽器的控制台中查看“Vue”選項卡。使用 npm 運行“npm list -g vue”命令。在 package.json 文件的“dependencies”對像中查找 Vue 項。對於 Vue CLI 項目,運行“vue --version”命令。檢查 HTML 文件中引用 Vue 文件的 &lt;script&gt; 標籤中的版本信息。

vue怎麼用函數截流 vue怎麼用函數截流 Apr 08, 2025 am 06:51 AM

Vue 中的函數截流是一種技術,用於限制函數在指定時間段內被調用的次數,防止性能問題。實現方法為:導入 lodash 庫:import { debounce } from 'lodash';使用 debounce 函數創建截流函數:const debouncedFunction = debounce(() =&gt; { / 邏輯 / }, 500);調用截流函數,控制函數在 500 毫秒內最多被調用一次。

See all articles