首頁 >web前端 >js教程 >使用beforeEnter鉤子函數(附程式碼)

使用beforeEnter鉤子函數(附程式碼)

php中世界最好的语言
php中世界最好的语言原創
2018-06-06 11:34:282228瀏覽

這次帶給大家使用beforeEnter鉤子函數(附程式碼),使用beforeEnter鉤子函數(的注意事項有哪些,下面就是實戰案例,一起來看一下。

為什麼要自造beforeEnter鉤子函數?

看下問題場景:項目中有一個單字清單頁面,每個cell都會備註該單字是否已經掌握,點擊cell進入詳情頁,可對該單字進行學習,並標記單字是否掌握,並且在詳情頁面中也可以透​​過點擊前進後退按鈕學習其他的單字。所以當我點擊返回時,單字清單要展示所有單字使用者掌握的最新情況。

最終的頁面關係是這樣的:

wordListPage ——> wordDetail (對一系列單字進行學習,退出)——> wordListPage(刷新單字列表)

對於上面的場景,使用Vue生命週期函數是不行的,因為Vue的生命週期函數如:beforeCreate 、created、beforeMounted、mounted等,只有在元件初始化的時候才會被調用,但是當元件(VM實例)來自於快取(如$route.go(-1) 、keep-alive)中時,生命週期函數將不會再被呼叫。因此,當我從單字詳情頁面回到清單頁面時,找不到一個恰當的時期去出發數據更新。所以上面的場景也就無法很好的去做處理。

#當然,對於上面的場景是比較少的,但是beforeEnter鉤子函數的存在還是必要的。

建構beforeEnter鉤子函數

依賴知識點:

  1. 路由:vue-router  

  2. 混入:mixin  

  3. 中央事件匯流排

1 .創建一個中央事件匯流排

對於中央事件匯流排,簡單理解,就是創建一個公共Vue實例(EventBus),在不同的地方使用相同實例觸發EventBus.$emit('demo')訊息,在想要監聽事件的位置使用公共Vue實例進行監聽EventBus.$on('demo',() => {})。再說白點,就是有這麼一個公共元件,它會再不同的地方發訊息,又在不同的地方自己去監聽訊息。所以說訊息的發送和接收都是它自己實現的,所以說我們稱之為中央事件總線。

代碼如下:libs/EventBus. js

import Vue from 'vue';
const EventBus = new Vue();
export default EventBus;

下面看下怎麼使用

2.路由鉤子函數beforeEach

透過beforeEach鉤子函數,實作路由切換時觸發對應元件的beforeEnter事件。

程式碼如下:router/index.js

import EventBus from '@/libs/EventBus';
router.beforeEach((to, from, next) => {
  //如:EventBus.$emit('homeBeforeEnter');
  EventBus.$emit(to.name + 'BeforeEnter'); 
  if (to.matched.some(route => route.meta.isAuth)) {
    ...
    next()
  } else {
    next()
  }
  
})

3.建立全域混入物件

這裡實作路由切換事件的監聽和元件實例鉤子函數beforeEnter的觸發。

libs/beforeEnterMixin.js

import EventBus from './EventBus';
export default {
  beforeCreate() {
    //获取当前路由名称,与前面使用to.name对应
    let vmName = this.$route.name;
    if (!vmName) {
      return;
    }
    // 当组件初始化时,先触发一次,后续将不再调用
    this.$options.beforeEnter();
    const beforeEnter = vmName + 'BeforeEnter';
    //监听路由切换时触发的...BeforeEnter事件
    //通过this.$options获取到实例中的beforeEnter钩子函数
    //监听到...BeforeEnter事件后,触发钩子函数beforeEnter调用
    EventBus.$on(beforeEnter, this.$options.beforeEnter);
  },
  //该函数在这里只作为占位,没有实际意义
  beforeEnter() {}
};

對於該混入對象,使用全域或局部混入都是可行的。

全域混入:main.js

import beforeEnterMixin from '@/libs/beforeEnterMixin';
Vue.mixin(beforeEnterMixin);

4.在元件中的使用

如:home.vue

<template>
  <p>
    首页
  </p>
</template>
<script>
export default {
  beforeEnter() {
    console.log('首页 beforeEnter...');
  },
  created() {
    console.log('首页 created...')
  }
}
</script>

至此,我們的beforeEnter 就完成了,可以做個demo自己測試下,目前本人在專案比較多的地方都會用到它。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

怎麼使用vue webpack做出非同步載入

vue router動態路由運算子路由

以上是使用beforeEnter鉤子函數(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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