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
  • asp之家 网络编程 m.aspxhome.com