beforeRouteLeave的使用方法
时间: 2023-06-11 16:10:11 浏览: 211
`beforeRouteLeave` 是 Vue Router 提供的一个路由导航守卫,用于在离开当前路由之前执行一些操作,比如弹出提示框询问用户是否确认离开当前页面。该方法可以在组件实例中定义,类似于 `created`、`mounted` 等生命周期钩子函数。
使用方法如下:
```javascript
export default {
// ...
beforeRouteLeave(to, from, next) {
// 在离开当前路由前执行一些操作
if (confirm('确定离开当前页面吗?')) {
next();
} else {
next(false);
}
}
}
```
在上述代码中,`beforeRouteLeave` 方法接收三个参数:
- `to`:即将进入的目标路由对象
- `from`:当前导航正要离开的路由对象
- `next`:用于路由导航的控制函数,可以调用 `next()` 直接进入下一个路由,或者调用 `next(false)` 取消当前导航,或者调用 `next('/path')` 或者 `next({ path: '/path' })` 跳转到指定的路由。
需要注意的是,如果在 `beforeRouteLeave` 中使用了异步操作,比如发送网络请求,需要在异步操作完成后手动调用 `next()`,否则导航将一直处于等待状态。例如:
```javascript
export default {
// ...
beforeRouteLeave(to, from, next) {
// 在离开当前路由前执行异步操作
axios.post('/api/logout').then(() => {
next();
}).catch(() => {
next(false);
});
}
}
```
阅读全文