vue跳转方式(打开新页面)及传参操作示例

时间:2021-05-26

本文实例讲述了vue跳转方式(打开新页面)及传参操作。分享给大家供大家参考,具体如下:

1. router-link跳转

// 直接写上跳转的地址<router-link to="/detail/one"> <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// 新窗口打开<router-link :to="{path:'/detail/three', query:{id:1,name:'vue'}}" target="_blank"></router-link>

2. this.$router.push跳转

toDeail (e) { this.$router.push({path: "/detail", query: {id: e}})}// 参数获取id = this.$route.query.idtoDeail (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')}

接收方怎么接收参数 this.$route.query.serid和this.$route.params.setid,以下举一个接收的例子

注意接收参数时是 $route 不是 $router

<template> <div> testDemo{{this.$route.query.setid}} </div></template>

接收的参数:

<template> <div>userlist--{{mallCode}} </div></template><script> export default { name: "UserList", date:function(){ return {"mallCode":mallCode} }, created(){ this.getParams() }, methods:{ getParams() { // 取到路由带过来的参数 const routerParams = this.$route.query.mallCode; this.mallCode = routerParams; console.log(this.$route.query); // 将数据放在当前组件的数据内 //this.mallInfo.searchMap.mallCode = routerParams; //this.keyupMallName() } } }</script><style scoped></style>

希望本文所述对大家vue.js程序设计有所帮助。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章