91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue導航鉤子怎么用

發布時間:2021-08-13 10:18:05 來源:億速云 閱讀:127 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關vue導航鉤子怎么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

導航鉤子

正如其名,vue-router 提供的導航鉤子主要用來攔截導航,讓它完成跳轉或取消。有多種方式可以在路由導航發生時執行鉤子:全局的, 單個路由獨享的, 或者組件級的。

全局鉤子

你可以使用 router.beforeEach 注冊一個全局的 before 鉤子:

const router = new VueRouter({ ... })
router.beforeEach((to, from, next) => {
 // ...
})

當一個導航觸發時,全局的 before 鉤子按照創建順序調用。鉤子是異步解析執行,此時導航在所有鉤子 resolve 完之前一直處于等待中。

每個鉤子方法接收三個參數:

to: Route: 即將要進入的目標 路由對象

from: Route: 當前導航正要離開的路由

next: Function: 一定要調用該方法來 resolve 這個鉤子。執行效果依賴 next 方法的調用參數。

next(): 進行管道中的下一個鉤子。如果全部鉤子執行完了,則導航的狀態就是confirmed (確認的)。

next(false): 中斷當前的導航。如果瀏覽器的 URL 改變了(可能是用戶手動或者瀏覽器后退按鈕),那么 URL 地址會重置到 from 路由對應的地址。

next('/') 或者 next({ path: '/' }): 跳轉到一個不同的地址。當前的導航被中斷,然后進行一個新的導航。

確保要調用 next 方法,否則鉤子就不會被 resolved。

同樣可以注冊一個全局的 after 鉤子,不過它不像 before 鉤子那樣,after 鉤子沒有next 方法,不能改變導航:

router.afterEach(route => {
 // ...
})

某個路由獨享的鉤子

你可以在路由配置上直接定義 beforeEnter 鉤子:

const router = new VueRouter({
 routes: [
 {
  path: '/foo',
  component: Foo,
  beforeEnter: (to, from, next) => {
  // ...
  }
 }
 ]
})

這些鉤子與全局 before 鉤子的方法參數是一樣的。

組件內的鉤子

最后,你可以使用 beforeRouteEnter 和 beforeRouteLeave,在路由組件內直接定義路由導航鉤子,

const Foo = {
 template: `...`,
 beforeRouteEnter (to, from, next) {
 // 在渲染該組件的對應路由被 confirm 前調用
 // 不!能!獲取組件實例 `this`
 // 因為當鉤子執行前,組件實例還沒被創建
 },
 beforeRouteLeave (to, from, next) {
 // 導航離開該組件的對應路由時調用
 // 可以訪問組件實例 `this`
 }
}

beforeRouteEnter 鉤子 不能 訪問 this,因為鉤子在導航確認前被調用,因此即將登場的新組件還沒被創建。

不過,你可以通過傳一個回調給 next來訪問組件實例。在導航被確認的時候執行回調,并且把組件實例作為回調方法的參數。

beforeRouteEnter (to, from, next) {
 next(vm => {
 // 通過 `vm` 訪問組件實例
 })
}

你可以 在 beforeRouteLeave 中直接訪問 this。這個 leave 鉤子通常用來禁止用戶在還未保存修改前突然離開。可以通過 next(false) 來取消導航。

關于“vue導航鉤子怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

息烽县| 丰都县| 平安县| 安仁县| 锦州市| 林口县| 东至县| 龙井市| 阜宁县| 西贡区| 临沭县| 抚松县| 彩票| 巧家县| 德安县| 河间市| 阳山县| 河曲县| 瑞金市| 罗定市| 丘北县| 洮南市| 嵊泗县| 虹口区| 江陵县| 从江县| 泸定县| 大安市| 方正县| 阳曲县| 墨江| 从江县| 万宁市| 宁津县| 上饶县| 崇仁县| 南投市| 永福县| 专栏| 翁源县| 垣曲县|