這篇文章帶給大家的內容是關於vue.js組件內部的導航守衛的介紹,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
beforeRouteEnter
beforeRouteUpdate (2.2 新增)
beforeRouteLeave
① beforeRouteEnter 進入元件之前
#進入該元件之前被調用,元件實例還沒有被創建,不能使用this關鍵字
不過,你可以透過傳一個回呼給next
來存取元件實例,也就是說可以透過next 來回調實例化後的元件,用next函數的vm 參數作為this
export default { name: "Admin", data(){ return{ infor:'hw' } }, beforeRouteEnter:(to,from,next)=>{ //此时该组件还没被实例化 alert(this.infor); //弹出消息框信息为 undefined next(vm =>{ //此时该组件被实例化了 alert(vm.infor); //弹出消息框信息为 hw }) } }
②beforeRouteLeave 離開元件之後
# 離開元件之後調用,可以呼叫this 關鍵字
export default { name: "Admin", beforeRouteLeave(to,from,next){ if(confirm("确定离开吗?") == true){ next() //跳转到另一个路由 }else{ next(false);//不跳转 } } }
③beforeRouteUpdate 此元件被重複使用時呼叫
此元件被重複使用時調用,可以調用this 關鍵字
beforeRouteUpdate (to, from, next) { // 在当前路由改变,但是该组件被复用时调用 // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候, // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。 // 可以访问组件实例 `this` }
相關推薦:
以上是vue.js組件內部的導航守衛的介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!