VUE router对象

本文介绍了Vue中三种路由跳转方法,this.$router.push()会向history栈添加记录,this.$router.replace()不添加新记录,this.$router.go(n)可前后跳转页面。还阐述了路由带查询参数query和路由参数params的传递及读取方法,以及二者区别。

1.this.$router.push()
描述:跳转到不同的url,但这个方法会向history栈添加一个记录,点击后退会返回到上一个页面。

2.this.$router.replace()
描述:同样是跳转到指定的url,但是这个方法不会向history里面添加新的记录,点击返回,会跳转到上上一个页面。上一个记录是不存在的。

3.this.$router.go(n)
相对于当前页面向前或向后跳转多少个页面,类似 window.history.go(n)。n可为正数可为负数。正数返回上一个页面

 

// 字符串
router.push('apple')
// 对象
router.push({path:'apple'})
// 命名路由
router.push({name: 'applename'})


//直接路由带查询参数query,地址栏变成 /apple?color=red
router.push({path: 'apple', query: {color: 'red' }})
// 命名路由带查询参数query,地址栏变成/apple?color=red
router.push({name: 'applename', query: {color: 'red' }})

读取参数方法:this.$route.query.color


//直接路由带路由参数params,params 不生效,如果提供了 path,params 会被忽略
router.push({path:'applename', params:{ color: 'red' }})
// 命名路由带路由参数params,地址栏是/apple/red
router.push({name:'applename', params:{ color: 'red' }})

读取参数方法:this.$route.params.color

注意:params传参,push里面只能是 name:'xxxx',不能是path:'/xxx',因为params只能用name来引入路由,如果这里写成了path,接收参数页面会是undefined!!!

另外,二者还有点区别,直白的来说query相当于get请求,页面跳转的时候,可以在地址栏看到请求参数,而params相当于post请求,参数不会再地址栏中显示

Vue RouterVue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页应用变得易如反掌。在 Vue Router 中传递对象,通常是通过路由的 `params` 或者 `query` 来实现的。 1. 使用 `params` 传递对象: 如果你想通过动态路由传递对象,可以在路由路径中使用参数,并在 `params` 中传递对象。首先,需要在路由配置中定义一个接收参数的路由: ```javascript { path: '/user/:id', component: User, } ``` 然后,在跳转到该路由的时候,将对象序列化后作为 `params` 传递: ```javascript this.$router.push({ name: 'User', params: { id: JSON.stringify(userObject) } }); ``` 在目标组件中,可以通过 `this.$route.params` 获取到序列化后的对象字符串,然后进行反序列化: ```javascript const userObject = JSON.parse(this.$route.params.id); ``` 2. 使用 `query` 传递对象: 另一种方法是通过查询字符串(query)传递对象。这种方式不需要在路由配置中做任何改变,只需要在跳转时将对象转换为查询参数: ```javascript this.$router.push({ name: 'User', query: { user: JSON.stringify(userObject) } }); ``` 在目标组件中,同样使用 `this.$route.query` 获取到序列化后的对象字符串,并反序列化: ```javascript const userObject = JSON.parse(this.$route.query.user); ``` 需要注意的是,在这两种方式中传递对象时,由于 URL 中只能包含字符串,因此对象必须先转换成字符串形式。而在目标组件中,需要将这个字符串再转换回对象
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值