问题描述:项目中,使用$router.push(参数)跳转同一路由页面,打开多个tab,数据均为最后一次打开的数据;
1、列表页面
2、从1进入的编辑详情:
3、从2进入的编辑详情:data:image/s3,"s3://crabby-images/913dd/913dd62f6618616b22bb3997f088564b57b42502" alt="在这里插入图片描述"
4、此时1的编辑详情内容也变成了2进入的编辑详情内容data:image/s3,"s3://crabby-images/2994a/2994a6512ef6cc599ffa948bf6826fdf98c476cc" alt="在这里插入图片描述"
解决方案一:
<template>
<router-view :key="key"></router-view>
</template>
<script>
export default {
computed: {
key() {
return this.$route.path + Date.now()
}
}
}
</script>
<style>
</style>
解决方案二(监听路由):
//解决进入不同row的详情,打开多个tab,数据均为最后一次打开的数据
watch: {
$route(to, from) {
if (to.query.id != from.query.id) {
this.invoiceItem = to.query
this.getInvoiceDetails();
}
},
}