vue监听路由变化的几种方式小结
作者:star-1331 时间:2024-05-21 10:28:41
监听路由变化的几种方式小结
vue页面开发中,我们经常需要根据路由的变化去实现一些操作,那么如何监听路由的变化呢?当然是利用VUE中的watch,请看代码。
一、监听路由从哪儿来到哪儿去
watch:{
?? ?$route(to,from){
?? ? ?console.log(from.path);//从哪来
?? ? ?console.log(to.path);//到哪去
?? ?}
}
二、监听路由变化获取新老路由信息
?watch:{
? ? $route:{
? ? ? handler(val,oldval){
? ? ? ? console.log(val);//新路由信息
? ? ? ? console.log(oldval);//老路由信息
? ? ? },
? ? ? // 深度观察监听
? ? ? deep: true
? ? }
? }
三、监听路由变化触发方法
methods:{
? getPath(){
? ? console.log(1111)
? }
},
watch:{
? '$route':'getPath'
}
四、全局监听路由
在app.vue的create种加入下面代码,然后进行判断
this.$router.beforeEach((to, from, next) => {
? ? console.log(to);
? ? next();
});
如何在组件中监听路由参数的变化?
当使用路由参数时,例如从 /user/foo 导航到 /user/bar,原来的组件实例会被复用。
因为两个路由都渲染同个组件,比起销毁再创建,复用则显得更加高效。不过,这也意味着组件的生命周期钩子不会再被调用。
那如果我们要在组件中监听路由参数的变化,就只能通过watch (监测变化) $route 对象,或使用 beforeRouteUpdate 的组件内守卫。
方式一: 监听 $route
const User = {
? template: '...',
? watch: {
? ? $route(to, from) {
? ? ? // 对路由变化作出响应...
? ? }
? }
}
方式二:通过组件内的导航守卫
beforeRouteUpdate ,(和created(){}生命周期函数同级别)
const User = {
? template: '...',
? beforeRouteUpdate(to, from, next) {
? ? // react to route changes...
? ? // don't forget to call next()
? }
}
来源:https://blog.csdn.net/weixin_40970987/article/details/82420390
标签:vue,监听,路由
0
投稿
猜你喜欢
通过python下载FTP上的文件夹的实现代码
2022-03-16 11:19:12
vuex页面刷新数据丢失问题的四种解决方式
2024-04-09 10:58:50
MongoDB与MySQL常用操作语句对照
2024-01-13 12:08:17
python 实现网上商城,转账,存取款等功能的信用卡系统
2022-05-26 15:19:36
利用python在excel里面直接使用sql函数的方法
2023-10-15 00:34:57
Zen Coding: 一种快速编写HTML/CSS代码[译]
2009-12-16 12:53:00
Python3.5装饰器原理及应用实例详解
2023-11-07 23:15:51
基于Bootstrap分页的实例讲解(必看篇)
2024-04-16 10:31:58
Navicat for MySQL 15注册激活详细教程
2024-01-19 00:05:16
python2.7读取文件夹下所有文件名称及内容的方法
2023-12-16 03:27:07
由Python运算π的值深入Python中科学计算的实现
2021-10-21 03:48:06
Python实现bilibili时间长度查询的示例代码
2022-11-24 15:52:16
一个基于ROW_NUMBER()的通用分页存储过程代码
2024-01-18 13:55:09
Django多层嵌套ManyToMany字段ORM操作详解
2023-07-01 02:26:28
vue项目实现图片懒加载的简单步骤
2024-05-10 14:16:06
基于Python Dash库制作酷炫的可视化大屏
2022-09-13 14:20:32
JS获取当前时间的年月日时分秒及时间的格式化的方法
2024-04-17 10:23:00
echarts动态获取Django数据的实现示例
2022-08-26 02:29:06
GO的锁和原子操作的示例详解
2024-05-05 09:30:57
TCP关闭问题详细介绍
2022-07-26 16:58:02