vue的跳转方式(打开新页面,传参)

本文详细介绍了Vue中实现页面跳转的四种方法:1) 使用`<router-link>`组件进行平滑跳转,包括直接指定路径和传递参数;2) 使用`this.$router.push`方法,通过path或name属性配合参数进行跳转;3) 使用`this.$router.replace`方法,无历史记录地跳转;4) 利用`$router.resolve`解析路由并用`window.open`打开新窗口。这些方法覆盖了不同场景下的页面导航需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.router-link跳转

// 直接写上跳转的地址
<router-link to="/detail/one" tag='a'  target="_blank" >
    <span class="spanfour" >link跳转</span>
</router-link>
 // 添加参数
<router-link :to="{path:'/detail/two', query:{id:1,name:'vue'}}"></router-link>

 // 参数获取
  id = this.$route.query.id

2.this.$router.push跳转

toDeail (e) {
   this.$router.push({path: "/detail", query: {id: e}})
 }
 // 参数获取
 id = this.$route.query.id
 
 toDeail (e) {
   this.$router.push({name: "/detail", params: {id: e}})
 }
 // 注意地址需写在 name后面
 //参数获取,params和query区别,query参数在地址栏显示,params的参数不在地址栏显示
 id = this.$route.params.id

3.this.$router.replace跳转

//和push的区别,push有记录一个history,replace没有
 toDeail (e) {
   this.$router.replace({name: '/detail', params: {id: e}})
 }

4.resolve跳转

resolve页面跳转可用新页面打开
 2.1.0版本后,使用路由对象的resolve方法解析路由,可以得到location、router、href等目标路由的信息。得到href就可以使用window.open开新窗口了(这边应用:https://segmentfault.com/q/1010000009557100下的一个回答)
 toDeail (e) {
   const new = this.$router.resolve({name: '/detail', params: {id: e}})
   window.open(new.href,'_blank')
 }

摘自:vue的跳转方式(打开新页面) - mouseleo - 博客园

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值