路径变化 $router $route的多种运用方式

一 、this.$router 和 this.$route 的区别

this.$router 实际上就是全局路由对象任何页面都可以调用 push(), go()等方法; 

this.$route  表示当前正在用于跳转的路由器对象,可以调用其name、path、query、params等属性。

二、$route对象

可以利用它进行一些信息的获取

1.$route.path
      字符串,对应当前路由的路径,总是解析为绝对路径,如 "/foo/bar"。
2.$route.params
      一个 key/value 对象,包含了 动态片段 和 全匹配片段,
      如果没有路由参数,就是一个空对象。
3.$route.query
      一个 key/value 对象,表示 URL 查询参数。
      例如,对于路径 /foo?user=1,则有 $route.query.user == 1,
      如果没有查询参数,则是个空对象。
4.$route.hash
      当前路由的 hash 值 (不带 #) ,如果没有 hash 值,则为空字符串。锚点
5.$route.fullPath
      完成解析后的 URL,包含查询参数和 hash 的完整路径。
6.$route.matched
      数组,包含当前匹配的路径中所包含的所有片段所对应的配置参数对象。
7.$route.name  当前路径名字
8.$route.meta  路由元信息

三、$router对象

1. 路由实例方法 push

// 字符串
      this.$router.push('home')
// 对象
      this.$router.push({ path: 'home' })
// 命名的路由
      this.$router.push({ name: 'user', params: { userId: 123 }})
ps:如何接收传过来的参数 => 在接收页,this.$route.query

// 带查询参数,变成 /register?plan=123
      this.$router.push({ path: 'register', query: { plan: '123' }})

        push方法其实和<router-link :to="...">是等同的。
        注意:push方法的跳转会向 history 栈添加一个新的记录,当我们点击浏览器的返回按钮时可以看到之前的页面。

2. 路由实例方法go

// 页面路由跳转 前进或者后退
this.$router.go(-1) // 后退

3 路由实例方法replace

//push方法会向 history 栈添加一个新的记录,而replace方法是替换当前的页面,
不会向 history 栈添加一个新的记录

<router-link to="/05" replace>05</router-link>

// 一般使用replace来做404页面
this.$router.replace('/')

四、具体实例

1.this.$route.path .indexOf()用于选择性展示页面 若地址栏中存在就展示描述的

2.this.$router.replace({ }) 可将路径替换到其他路径

 3.this.$router.push(" ")  直接在当前地址栏后面加 /register 跳转到该组件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值