欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Vue2.X的路由管理記錄之 鉤子函數(shù)(切割流水線)

 更新時(shí)間:2017年05月02日 11:56:16   作者:一直在尋  
本篇文章主要介紹了Vue2.X的路由管理記錄之 鉤子函數(shù)(切割流水線),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

$route可以在子組件任何地方調(diào)用,代表當(dāng)前路由對(duì)象,這個(gè)屬性是只讀的,里面的屬性是 immutable(不可變) 的,不過你可以 watch(監(jiān)測(cè)變化) 它。

導(dǎo)航和鉤子函數(shù):

導(dǎo)航:路由正在發(fā)生改變   關(guān)鍵字:路由  變

鉤子函數(shù):在路由切換的不同階段調(diào)用不同的節(jié)點(diǎn)函數(shù)(鉤子函數(shù)在我看來也就是:某個(gè)節(jié)點(diǎn)和時(shí)機(jī)觸發(fā)的函數(shù))

 兩者關(guān)系:

鉤子函數(shù) ---> 導(dǎo)航 :鉤子函數(shù)   主要用來攔截導(dǎo)航,讓它完成跳轉(zhuǎn)或取消,在導(dǎo)航的不同階段來執(zhí)行不同的函數(shù) ,最后鉤子函數(shù)的執(zhí)行結(jié)果會(huì)告訴導(dǎo)航怎么做。。

導(dǎo)航 ---> 鉤子函數(shù) :導(dǎo)航在所有鉤子 resolve 完之前一直處于 等待中,等待鉤子函數(shù)告訴它下一步該怎么做。用next()來指定。

全局鉤子函數(shù)之   全局的beforeEach鉤子:

 例子: 在每次發(fā)生路由導(dǎo)航是最開始先檢測(cè)用戶是否登錄

router.beforeEach(({meta, path}, from, next) => {  

  const {auth = true} = meta   // meta代表的是to中的meta對(duì)象,path代表的是to中的path對(duì)象

  var isLogin = Boolean(store.state.user.id)  // true用戶已登錄, false用戶未登錄 
  
  if (auth && !isLogin && path !== '/login') {  // auth 代表需要通過用戶身份驗(yàn)證,默認(rèn)為true,代表需要被驗(yàn)證, false為不用檢驗(yàn)
    return next({ path: '/login' })  // 跳轉(zhuǎn)到login頁面
  }


  next()  // 進(jìn)行下一個(gè)鉤子函數(shù)
})

先說這個(gè)beforeEach的鉤子函數(shù),它是一個(gè)全局的before 鉤子函數(shù), (before each)意思是在 每次每一個(gè)路由改變的時(shí)候都得執(zhí)行一遍。

它的三個(gè)參數(shù):

  1. to: (Route路由對(duì)象)  即將要進(jìn)入的目標(biāo) 路由對(duì)象    to對(duì)象下面的屬性: path   params  query   hash   fullPath    matched   name    meta(在matched下,但是本例可以直接用)
  2. from: (Route路由對(duì)象)  當(dāng)前導(dǎo)航正要離開的路由
  3. next: (Function函數(shù))   一定要調(diào)用該方法來 resolve 這個(gè)鉤子。  調(diào)用方法:next(參數(shù)或者空)   ***必須調(diào)用

next(無參數(shù)的時(shí)候):  進(jìn)行管道中的下一個(gè)鉤子,如果走到最后一個(gè)鉤子函數(shù),那么  導(dǎo)航的狀態(tài)就是 confirmed (確認(rèn)的)

next('/') 或者 next({ path: '/' }): 跳轉(zhuǎn)到一個(gè)不同的地址。當(dāng)前的導(dǎo)航被中斷,然后進(jìn)行一個(gè)新的導(dǎo)航。

 全局鉤子函數(shù)之   全局的afterEach鉤子:

after 鉤子沒有 next 方法,不能改變導(dǎo)航,代表已經(jīng)確定好了導(dǎo)航怎么去執(zhí)行后,附帶的一個(gè)執(zhí)行鉤子函數(shù)

組件內(nèi)的鉤子函數(shù):( beforeRouteEnter 和 beforeRouteLeave 再加一個(gè) watch函數(shù) )

vue2.X的組件內(nèi)鉤子函數(shù)比vue1.X減少了許多。。

https://github.com/vuejs/vue-router/blob/43183911dedfbb30ebacccf2d76ced74d998448a/examples/navigation-guards/app.js#L49 

  1. 使用組件自身的生命周期鉤子函數(shù)來替代 activate 和 deactivate
  2. 在 $router 上使用 watcher 來響應(yīng)路由改變
  3. canActivate 可以被 router 的配置中的 beforeEnter 中實(shí)現(xiàn)
  4. canDeactivate 已經(jīng)被 beforeRouteLeave 取代, 后者在一個(gè)組件的根級(jí)定義中指定。這個(gè)鉤子函數(shù)在調(diào)用時(shí)是將組件的實(shí)例作為其上下文的。
  5. canReuse 已經(jīng)被移除,因其容易混淆且很少被用到。
  6. 用ajax獲取數(shù)據(jù)的data(to, from, next) 鉤子用組件內(nèi) beforeRouteEnter (to, from, next)來替代 

先來解釋下vue1.X中的組件內(nèi)鉤子函數(shù):

組件的鉤子函數(shù)一共6個(gè):

  1. data:可以設(shè)置組件的data
  2. activate:激活組件
  3. deactivate:禁用組件
  4. canActivate:組件是否可以被激活
  5. canDeactivate:組件是否可以被禁用
  6. canReuse:組件是否可以被重用

 vue-router1.X中   每個(gè)切換鉤子函數(shù)都會(huì)接受一個(gè) transition 對(duì)象作為參數(shù),參數(shù)下有5個(gè)屬性/方法  to from next()  abort([reason]) redirect(path) 

 vue-router2.X中   其中后三個(gè)都?xì)w到next()函數(shù)里了  ,  所以next()函數(shù)改為3個(gè)直接的參數(shù)  ( to from next() )

例子:

 

 

路由的切換分為三個(gè)階段:可重用階段,驗(yàn)證階段和激活階段

以   home/news  切換到   home/message  為例來描述各個(gè)階段

 可以重用組件Home,因?yàn)橹匦落秩竞?,組件Home依然保持不變。

確保切換效果有效——也就是說,為保證切換中涉及的所有組件都能按照期望的那樣被停用/激活

需要停用并移除組件News,啟用并激活組件Message。

此階段對(duì)應(yīng)鉤子函數(shù)的調(diào)用順序和驗(yàn)證階段相同,其目的是在組件切換真正執(zhí)行之前提供一個(gè)進(jìn)行清理和準(zhǔn)備的機(jī)會(huì)。

界面的更新會(huì)等到所有受影響組件的 deactivate 和 activate 鉤子函數(shù)執(zhí)行之后才進(jìn)行。

data 這個(gè)鉤子函數(shù)會(huì)在 activate 之后被調(diào)用,或者當(dāng)前組件組件可以重用時(shí)也會(huì)被調(diào)用。

通過上述vue-router1.x,那么2.x的執(zhí)行順序可以如以下方式理解:

  鉤子的執(zhí)行順序就是:1、最開始beforeEach鉤子,

            2、然后舊的組件是否能重用canReuse,不重用的是否能canDeactivate,再看新的組件是否canActivate,再后把不能重用的能銷毀的給deactivate

            3、這樣舊的不重用的組件就結(jié)束了它的生命周期了,所以這時(shí)候在結(jié)束生命周期之前執(zhí)行調(diào)用afterEach函數(shù)

            4、新組建開始的話先是activate,然后再是data,如果重用的話就沒有銷毀,所以一直在activate中,只是執(zhí)行data鉤子。

那么這樣的鉤子函數(shù)對(duì)應(yīng)給vue2.x會(huì)是怎樣的呢???(--------待驗(yàn)證-------)

  1、最先執(zhí)行的是 beforeEach鉤子,所有路由開始的時(shí)候最先執(zhí)行。

  2、然后就是 router 的配置中的beforeEnter。

  3、接下來是    路由的  beforeRouteEnter  -----    然后是組件自身的生命周期   ------  路由 beforeRouteLeave

  beforeRouteEnter (to, from, next) {}  與  beforeRouteLeave不再是組件中route配置下的對(duì)象了,他們和data處于同級(jí)別的地位。

可以看出:  新設(shè)計(jì)的路由     淡化了組件自身跟著路由生命周期變化而變化,而是依賴組件自身的生命周期,只有兩個(gè)簡(jiǎn)單的   路由級(jí)別的鉤子 beforeRouteEnter beforeRouteLeave

那么接下來:

  ajax調(diào)用時(shí)機(jī):相對(duì)于組件來說的,而且應(yīng)該是在路由進(jìn)入之前開始準(zhǔn)備的 所以beforeRouteEnter是調(diào)用ajax的時(shí)機(jī)。

  watch這一函數(shù)可以監(jiān)聽路由$route變化。

  beforeRouteLeave在組件的生命周期完成后,且舊路由即將切換走,新路由beforeEach的時(shí)機(jī)執(zhí)行。

watch的使用時(shí)機(jī):

當(dāng)使用路由參數(shù)時(shí),例如從 /user/foo 導(dǎo)航到 user/bar,原來的組件實(shí)例會(huì)被復(fù)用。因?yàn)閮蓚€(gè)路由都渲染同個(gè)組件,比起銷毀再創(chuàng)建,復(fù)用則顯得更加高效。

不過,這也意味著   組件的生命周期鉤子不會(huì)再被調(diào)用。

復(fù)用組件時(shí),想對(duì)路由參數(shù)的變化作出響應(yīng)的話,你可以簡(jiǎn)單地 watch(監(jiān)測(cè)變化) $route 對(duì)象:

const User = {
 template: '...',
 1、watch: {
  '$route' (to, from) {
   // 對(duì)路由變化作出響應(yīng)...
  }
 }
 2、watch: { 
   '$route': 'fetchData'    // 如果路由有變化,會(huì)再次執(zhí)行fetchData方法
 },

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue條件循環(huán)判斷+計(jì)算屬性+綁定樣式v-bind的實(shí)例

    Vue條件循環(huán)判斷+計(jì)算屬性+綁定樣式v-bind的實(shí)例

    今天小編就為大家分享一篇Vue條件循環(huán)判斷+計(jì)算屬性+綁定樣式v-bind的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue3.0使用taro-ui-vue3引入組件不生效的問題及解決

    vue3.0使用taro-ui-vue3引入組件不生效的問題及解決

    這篇文章主要介紹了vue3.0使用taro-ui-vue3引入組件不生效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue整合項(xiàng)目中百度API示例詳解

    vue整合項(xiàng)目中百度API示例詳解

    這篇文章主要為大家介紹了vue整合項(xiàng)目中百度API示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue3自己封裝面包屑功能組件的幾種方式

    vue3自己封裝面包屑功能組件的幾種方式

    網(wǎng)站中我們經(jīng)??吹接袀€(gè)導(dǎo)航路徑,可以直觀地顯示當(dāng)前頁面的路徑,并快速返回之前的任意頁面,這是一個(gè)非常實(shí)用的功能,也是在Web前端必備的導(dǎo)航UI之一,這篇文章主要給大家介紹了關(guān)于vue3自己封裝面包屑功能組件的幾種方式,需要的朋友可以參考下
    2021-09-09
  • vant之van-list的使用及踩坑記錄

    vant之van-list的使用及踩坑記錄

    這篇文章主要介紹了vant之van-list的使用及踩坑記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • intellij?idea+vue前端調(diào)試配置圖文教程

    intellij?idea+vue前端調(diào)試配置圖文教程

    在Vue項(xiàng)目開發(fā)過程中,當(dāng)遇到應(yīng)用邏輯出現(xiàn)錯(cuò)誤,但又無法準(zhǔn)確定位的時(shí)候,知曉Vue項(xiàng)目調(diào)試技巧至關(guān)重要,debug是必備技能,這篇文章主要給大家介紹了關(guān)于intellij?idea+vue前端調(diào)試配置的相關(guān)資料,需要的朋友可以參考下
    2024-09-09
  • vue如何將導(dǎo)航欄、頂部欄設(shè)置為公共頁面

    vue如何將導(dǎo)航欄、頂部欄設(shè)置為公共頁面

    這篇文章主要介紹了vue如何將導(dǎo)航欄、頂部欄設(shè)置為公共頁面問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue3中組件數(shù)據(jù)通信方式總結(jié)

    Vue3中組件數(shù)據(jù)通信方式總結(jié)

    如果在面試中,面試官問你Vue組件之間有哪些數(shù)據(jù)通信方式,你會(huì)怎么回復(fù),不要擔(dān)心,本文為大家整理了超全的Vue3中組件數(shù)據(jù)通信方式,需要的小伙伴快收藏起來吧
    2023-06-06
  • Vue中使用eslint和prettier格式化代碼方式

    Vue中使用eslint和prettier格式化代碼方式

    這篇文章主要介紹了Vue中使用eslint和prettier格式化代碼方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue3中Cesium地圖初始化及地圖控件配置方法

    Vue3中Cesium地圖初始化及地圖控件配置方法

    本文中,我們主要介紹Cesium在Vue3運(yùn)行環(huán)境的配置,及Cesium實(shí)例中控件的顯隱設(shè)置,本項(xiàng)目基于pnpm安裝,也可使用其他包管理器進(jìn)行安裝,如npm或yarn,本文通過示例代碼對(duì)vue初始化Cesium地圖相關(guān)知識(shí)介紹的非常詳細(xì),需要的朋友參考下吧
    2023-07-07

最新評(píng)論