1. router-link跳转
// 直接写上跳转的地址
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) {
constnew = this.$router.resolve({name: '/detail', params: {id: e}})
window.open(new.href,'_blank')
}
接收方怎么接收参数 this.$route.query.serid和this.$route.params.setid,以下举一个接收的例子
注意接收参数时是 $route 不是 $router
接收的参数:
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()
}
}
}
转 : https://blog.csdn.net/qq_28353055/article/details/84099004
https://blog.csdn.net/Janus_lian/article/details/84965459