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

詳解vue beforeRouteEnter 異步獲取數(shù)據(jù)給實(shí)例問(wèn)題

 更新時(shí)間:2019年08月09日 08:24:19   作者:Alfred  
這篇文章主要介紹了vue beforeRouteEnter 異步獲取數(shù)據(jù)給實(shí)例問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

場(chǎng)景: vue-router 路由鉤子 beforeRouteEnter 可以用來(lái)在初始進(jìn)入頁(yè)面前,http 異步獲取數(shù)據(jù) mockData ,預(yù)先判斷是進(jìn)入 A 頁(yè)、還是 B 頁(yè),還是留在本頁(yè);而如果留在本頁(yè)的話(huà),還需要在 mounted 根據(jù) mockData 來(lái)判斷顯示哪種狀態(tài)(可以在本頁(yè)面實(shí)例創(chuàng)建后,重新發(fā)起 http 請(qǐng)求獲取 mockData ,但是沒(méi)有必要,造成代碼冗余);

執(zhí)行順序:

async beforeRouteEnter(to, from, next) {
   let res = await gameData()
   console.log('beforeRouteEnter start');
   next(vm => {
    console.log("vm start")
    vm.is_exchange = res.is_exchange
    vm.is_finish = res.is_finish
   })
 },
 beforeCreate() {
  console.log("beforeCreate start")
 },
 mounted(){
  console.log('mounted start');
  if(this.is_finish){
   this.modalMsg="活動(dòng)已結(jié)束"
   return;
  }
  if(this.is_exchange){
   this.modalMsg="您已兌換獎(jiǎng)品"
   return;
  }
 }

打印結(jié)果如下:

beforeRouteEnter start

beforeCreate start

mounted start

vm start

由打印結(jié)果,我們可以總結(jié) beforeRouteEnter 鉤子確實(shí)在 vue 實(shí)例創(chuàng)建前執(zhí)行,但是其 next 函數(shù)中 vm 回調(diào)不是同步執(zhí)行,而是等到 mounted 執(zhí)行完之后,才執(zhí)行 。

癥結(jié):因?yàn)槲覀円鶕?jù) mockData 中的 is_exchange 和 is_finish 參數(shù)來(lái)判斷決定頁(yè)面初始狀態(tài),此過(guò)程需要在 mounted 中執(zhí)行;但是 mounted 執(zhí)行時(shí), vm 還未執(zhí)行,即 mounted 拿不到

is_exchange 和 is_finish 這兩個(gè)值,這樣就造成了沖突;

解決:在 next 中 打印 vm ,發(fā)現(xiàn) vm 就是當(dāng)前 vue 實(shí)例對(duì)象,即可以使用 vm 調(diào)用所有當(dāng)前實(shí)例的變量和方法;那依次,能否將判斷邏輯寫(xiě)入 methods 中一個(gè)方法中,使用 vm 來(lái)調(diào)用呢?

async beforeRouteEnter(to, from, next) {
   let res = await gameData()
   console.log('beforeRouteEnter start');
   next(vm => {
    console.log("vm start")
    vm.is_exchange = res.is_exchange
    vm.is_finish = res.is_finish

    vm.judge();//賦值之后,此處調(diào)用判斷方法
   })
 },
 beforeCreate() {
  console.log("beforeCreate start")
 },
 mounted(){
  console.log('mounted start');
 },
 methods:{
  judge(){// 將判斷邏輯寫(xiě)入judge方法
  if(this.is_finish){
   this.modalMsg="活動(dòng)已結(jié)束"
   return;
  }
  if(this.is_exchange){
   this.modalMsg="您已兌換獎(jiǎng)品"
   return;
  }
  }
 }

至此,問(wèn)題解決。有同學(xué)可能會(huì)問(wèn),在 vm 中調(diào)用 judge 方法時(shí), mounted 已執(zhí)行,此時(shí)頁(yè)面已渲染,再去判斷初始狀態(tài),會(huì)不會(huì)有閃爍問(wèn)題?本人經(jīng)過(guò)測(cè)試,發(fā)現(xiàn)不會(huì),據(jù)此推斷,在 mounted 執(zhí)行結(jié)束之后,頁(yè)面沒(méi)有開(kāi)始更新動(dòng)作,而是在執(zhí)行完 vm 回調(diào)之后,再去渲染。這樣的話(huà),邏輯上就行得通了,但是這個(gè)只是推斷,還需要在源碼層面找到依據(jù)才可以。

github地址

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

相關(guān)文章

  • 詳解van-cell如何使用插槽

    詳解van-cell如何使用插槽

    這篇文章主要為大家介紹了van-cell如何使用插槽詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • vue-video-player?播放m3u8視頻流的實(shí)現(xiàn)

    vue-video-player?播放m3u8視頻流的實(shí)現(xiàn)

    本文主要介紹了vue-video-player?播放m3u8視頻流的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • vue項(xiàng)目使用axios封裝request請(qǐng)求的過(guò)程

    vue項(xiàng)目使用axios封裝request請(qǐng)求的過(guò)程

    這篇文章主要介紹了vue項(xiàng)目使用axios封裝request請(qǐng)求,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • Ant design vue table 單擊行選中 勾選checkbox教程

    Ant design vue table 單擊行選中 勾選checkbox教程

    這篇文章主要介紹了Ant design vue table 單擊行選中 勾選checkbox教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • vue?data中的return使用方法示例

    vue?data中的return使用方法示例

    當(dāng)一個(gè)組件被定義,data必須聲明為返回一個(gè)初始數(shù)據(jù)對(duì)象的函數(shù),因?yàn)榻M件可能被用來(lái)創(chuàng)建多個(gè)實(shí)例,下面這篇文章主要給大家介紹了關(guān)于vue?data中return使用,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • Vue中傳遞自定義參數(shù)到后端、后端獲取數(shù)據(jù)并使用Map接收參數(shù)

    Vue中傳遞自定義參數(shù)到后端、后端獲取數(shù)據(jù)并使用Map接收參數(shù)

    有些傳遞的參數(shù)是直接拼接到URL地址欄中的、但是為了統(tǒng)一管理、不能將傳遞的參數(shù)直接拼接到地址欄中,接下來(lái)通過(guò)本文給大家介紹Vue中傳遞自定義參數(shù)到后端、后端獲取數(shù)據(jù)并使用Map接收參數(shù),感興趣的朋友一起看看吧
    2022-10-10
  • vue數(shù)組對(duì)象排序的實(shí)現(xiàn)代碼

    vue數(shù)組對(duì)象排序的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue數(shù)組對(duì)象排序的實(shí)現(xiàn)代碼,這里整理了詳細(xì)的代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-06-06
  • Vue+ElementUI踩坑之動(dòng)態(tài)顯示/隱藏表格的列el-table-column問(wèn)題

    Vue+ElementUI踩坑之動(dòng)態(tài)顯示/隱藏表格的列el-table-column問(wèn)題

    這篇文章主要介紹了Vue+ElementUI踩坑之動(dòng)態(tài)顯示/隱藏表格的列el-table-column問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue如何實(shí)現(xiàn)動(dòng)態(tài)的選中狀態(tài)切換效果

    vue如何實(shí)現(xiàn)動(dòng)態(tài)的選中狀態(tài)切換效果

    這篇文章主要介紹了vue如何實(shí)現(xiàn)動(dòng)態(tài)的選中狀態(tài)切換效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue 自定義右鍵樣式的實(shí)例代碼

    vue 自定義右鍵樣式的實(shí)例代碼

    這篇文章主要介紹了vue 自定義右鍵樣式的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論