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

溫馨提示×

溫馨提示×

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

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

如何使用vue-route的beforeEach實現導航守衛功能

發布時間:2021-05-21 11:31:55 來源:億速云 閱讀:196 作者:小新 欄目:web開發

這篇文章主要介紹如何使用vue-route的beforeEach實現導航守衛功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

路由跳轉前做一些驗證,比如登錄驗證(未登錄去登錄頁),是網站中的普遍需求。對此,vue-route 提供的 beforeRouteUpdate 可以方便地實現導航守衛(navigation-guards)。

導航守衛(navigation-guards)這個名字,聽起來怪怪的,但既然官方文檔是這樣翻譯的,就姑且這么叫吧。

貼上文檔地址:https://router.vuejs.org/zh-cn/advanced/navigation-guards.html

先來摘抄一段文檔中beforeRouteUpdate 的用法:

你可以使用 router.beforeEach 注冊一個全局前置守衛:

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

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

每個守衛方法接收三個參數:

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

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

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

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

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

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

next(error): (2.4.0+) 如果傳入 next 的參數是一個 Error 實例,則導航會被終止且該錯誤會被傳遞給 router.onError() 注冊過的回調。

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

下面寫一個例子,上一篇博客中我們的賬戶頁,包括課程和訂單,都需要在跳轉前判斷是不是已登錄;已登錄的情況再去登錄頁,跳轉至首頁:

const vueRouter = new Router({ 
  routes: [ 
    //...... 
    { 
     path: '/account', 
     name: 'account', 
     component: Account, 
     children: [ 
      {name: 'course', path: 'course', component: CourseList}, 
      {name: 'order', path: 'order', component: OrderList} 
     ] 
    } 
  ] 
}); 
vueRouter.beforeEach(function (to, from, next) { 
  const nextRoute = [ 'account', 'order', 'course']; 
  const auth = store.state.auth; 
  //跳轉至上述3個頁面 
  if (nextRoute.indexOf(to.name) >= 0) { 
    //未登錄 
    if (!store.state.auth.IsLogin) { 
      vueRouter.push({name: 'login'}) 
    } 
  } 
  //已登錄的情況再去登錄頁,跳轉至首頁 
  if (to.name === 'login') { 
    if (auth.IsLogin) { 
      vueRouter.push({name: 'home'}); 
    } 
  } 
  next(); 
});

vue是什么

Vue是一套用于構建用戶界面的漸進式JavaScript框架,Vue與其它大型框架的區別是,使用Vue可以自底向上逐層應用,其核心庫只關注視圖層,方便與第三方庫和項目整合,且使用Vue可以采用單文件組件和Vue生態系統支持的庫開發復雜的單頁應用。

以上是“如何使用vue-route的beforeEach實現導航守衛功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

英山县| 黑龙江省| 府谷县| 油尖旺区| 揭阳市| 桓仁| 土默特右旗| 榆中县| 五指山市| 卓尼县| 文成县| 左贡县| 襄城县| 安宁市| 乌拉特前旗| 育儿| 南丰县| 拉萨市| 沙雅县| 金昌市| 灌南县| 峡江县| 遂平县| 涪陵区| 竹溪县| 菏泽市| 德兴市| 扬中市| 永安市| 左权县| 黔西| 察隅县| 牟定县| 科尔| 凭祥市| 茌平县| 原平市| 施秉县| 辽中县| 文山县| 万安县|