求助前端大佬们, 一个ElementPlus数据渲染和更新的问题

有这样一个页面, 列表也点击商品编号, 弹窗显示商品信息; 但是目前有一个问题, 就是关闭弹窗后, 点击下一个商品, 显示的还是上一个的商品信息, 是不是需要监听id的变化?

1.首页 index.vue

<el-link type="success" @dblclick="openDetail(scope.row.id)">{{scope.row.id}}</el-link>

<Detail :id="openId" />

2.弹窗页面

<template>
  <div>
       <el-dialog v-model="isOpen" title="商品信息">

           <el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick">
               <el-tab-pane label="商品信息" name="content1">{{  content1 }}</el-tab-pane>

               <el-tab-pane label="订单日志" name="content2">
                  <el-descriptions title="订单日志"  :column="2" :border="true">
                    <el-descriptions-item v-for="item in content2" :label="item.title" >{{ item.id }}</el-descriptions-item>
                  </el-descriptions>
               </el-tab-pane>

               <el-tab-pane label="采购日志" name="content3">{{  content3 }}</el-tab-pane>

               <el-tab-pane label="库存日志" name="content4">{{  content4 }}</el-tab-pane>
           </el-tabs>
       </el-dialog>
  </div>
</template>

cleanXss
import { ref, inject } from 'vue'
import type { TabsPaneContext } from 'element-plus'
import {getGoodsInfo, getGoodsOrder} from '/@/api/public/goods/goods'

const activeName = ref('content1')

const content1 = ref();
const content2 = ref([] as any[]);
const content3 = ref();
const content4 = ref();

const props = defineProps({
  id: String, // 假设 title 是字符串类型,根据你的实际需要修改
})


const handleClick = (tab: TabsPaneContext, event: Event) => {
    console.log(tab.index);
    switch (tab.index) {
      case '0':
        content1.value = "获取商品信息";
        break;
      case '1':
        // content2.value = [{title:"张三", id: 90}, {title:"李四", id: 23}];
        getGoodsOrder(props.id).then( (res) => {
          content2.value = res.data.list
        })
        break;
      case '2':
        content3.value = "获取采购日志";
        break;
      case '3':
        content4.value = "获取库存日志";
        break;
    }
}
// 弹窗
const isOpen = inject('isOpen')
cleanXss
1个回答默认排序 投票数排序
Desolate
Desolate
这家伙真的懒
1年前

很简单啊,大概率是api返回没那么快,弹窗里还是之前的信息,加个方法,关闭弹窗的时候把弹窗的信息置空就好了

cainiao2023
cainiao2023回复Desolate
这家伙很懒,什么也没写~
1年前

感谢, 我试试

请先登录
0
1
1
2