关于网友提出的“ (vue.js)vue-router go-1后退时怎么带参数?”问题疑问,本网通过在网上对“ (vue.js)vue-router go-1后退时怎么带参数?”有关的相关答案进行了整理,供用户进行参考,详细问题解答如下:
问题: (vue.js)vue-router go-1后退时怎么带参数?
描述://指定跳转到user页面,可带参数
router.go({name: 'user', params: {userId: 1}});
//不知道页面名,按历史记录跳转到上一页(这种情况应该怎么带参数???)
router.go(-1);
解决方案1:你this.$router.back()不就自己回去了,需要判断从哪进来的?
解决方案2:官网 grouter.go(-1) // 后退一步记录,等同于 history.back() 是无法带参数的
2个解决办法: 1. 以路由方式跳转到上一个页面,而非返回 2.可以通过store或者vuex,实现数据共享。
解决方案3:这本来就违背了历史记录的意思,如果是带上参数访问,那就应该是前进。
另外SPA又不存在数据传递的问题,为什么后退需要带参数?
解决方案4:问题已经解决了! (并非回退操作就不能带参数,如有需要的参考此类做法)
业务需求
这意味着“医院列表页”,并不知道也不需要知道,访问的上一个页面是哪个页面,只需要选择完医院之后返回就可以了。
当然也可以通过传参来告诉医院列表页,上一个页面的name是什么,然后再回退回去。但如果页面多了,想象一下医院列表页的判断代码会有多少?



解决方案
1. 声明一个空的Vue模块eventBus
import Vue from 'vue'
/**
* 定义空的vue实例,作为 eventbus实现非父子组件之间的通信(vue2.x中去掉了broadcast)
*/
var eventBus = new Vue({});
export default eventBus;
2. “医院列表页”通过eventBus.$emit
传参给上一个页面
import eventBus from '../service/eventbus.js';
methods:{
//列表选中具体医院的点击事件
goback(hospital){
//传递一个map,choiceHospital是key,hospital是value
eventBus.$emit('choiceHospital',hospital);
//调用router回退页面
this.$router.go(-1);
}
}
3. “首页”以及“预约”页面接收参数
import eventBus from '../service/eventbus.js';
//每次激活时
activated(){
//根据key名获取传递回来的参数,data就是map
eventBus.$on('choiceHospital', function(data){
//赋值给首页的附近医院数据模型
this.nearestOrg = data;
}.bind(this));
},
参考
以上介绍了“ (vue.js)vue-router go-1后退时怎么带参数?”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:http://www.codes51.com/itwd/4290380.html