Vue的路由系統允許我們在路由導航過程中添加一些鉤子函數。其中,beforeRouteEnter鉤子函數是在路由進入之前被調用的。它可以用來進行一些異步操作,例如獲取數據或從API檢索數據。在這個鉤子被調用時,組件實例還沒有被創建,因此無法訪問this對象。但是,我們可以使用next函數來傳遞一個回調函數,當組件實例被創建時,該回調函數會被執行。
beforeRouteEnter (to, from, next) { fetchData(function (data) { next(vm =>{ vm.data = data }) }) }
在這個示例中,我們定義了一個beforeRouteEnter鉤子函數,并使用fetchData函數來獲取數據。fetchData函數是異步的,因此我們將next函數作為參數傳遞給它。當fetchData函數完成并返回數據時,我們將使用next函數來訪問組件實例,并將數據分配給vm.data。
需要注意的是,在使用 next 回調之前,我們無法訪問組件實例。因此,我們無法直接修改組件中的數據或調用其方法。如果我們需要在 beforeRouteEnter 中對組件進行更多的修改,可以使用 beforeCreate 鉤子函數。
beforeRouteEnter (to, from, next) { next(vm =>{ vm.total = 0 vm.products.forEach(p =>{ vm.total += p.price }) }) } beforeCreate () { this.products = fetchData() }
在這個示例中,我們在beforeCreate鉤子函數中調用fetchData函數來獲取數據。然后,在beforeRouteEnter中,我們可以使用next回調來訪問組件實例,并通過計算來計算總價。在這種情況下,我們使用了 beforeCreate 鉤子函數,因為我們需要在組件實例化之前加載數據。