table表格的某一行数据如何回填

目的:table表格的某一行数据的输入框按钮触发对话框,对话框选择的数据再回填到table表格的这一行中。

1.插槽中传递本行的index: v-slot="{ row, $index }"

2.点击事件或者change事件传递index: @click="val => tpmClicked($index)"

  1. 记录这个index值:

    const rowIndexTPM = ref<number>();
    const tpmClicked = async index => {
    rowIndexTPM.value = index;
    dialogTPMVisible.value = true;
    };

  2. 对话框选择后触发事件,使用这个index值:

    const TPMchangeInfo = (jobNumber: string) => {
    requireList.value[rowIndexTPM.value].JobNumber = jobNumber;
    dialogTPMVisible.value = false;
    changeInfo(requireList.value[rowIndexTPM.value]);
    };

代码数据:

复制代码
1. 记录index
    <el-table-column label="工号" prop="JobNumber">
      <template v-slot="{ row, $index }">
        <span v-if="editStatus">
          <el-input
            type="text"
            v-model="row.JobNumber"
            placeholder="请输入:"
            @change="val => changeInfo(row)"
          >
            <template #suffix v-if="row.WorkerRole == 'TPM'">
              <el-button
                type="primary"
                @click="val => tpmClicked($index)"
                v-if="row.WorkerRole == 'TPM'"
                link
              >
                <el-icon>
                  <Connection />
                </el-icon>
              </el-button>
            </template>
          </el-input>
        </span>
        <span v-else>{{ row.JobNumber }}</span>
      </template>
    </el-table-column>



-->  触发的事件:
const rowIndexTPM = ref<number>();
const tpmClicked = async index => {
  rowIndexTPM.value = index;
  dialogTPMVisible.value = true;
};



2.对话框:
<el-dialog v-model="dialogTPMVisible" title="请选择TPM工号" width="20%">
    <el-tree-select
      v-model="Value"
      :data="TPMListInfo"
      filterable
      placeholder="请输入:"
      @change="val => TPMchangeInfo(val)"
    />
  </el-dialog>

--> 事件触发:
const TPMchangeInfo = (jobNumber: string) => {
  requireList.value[rowIndexTPM.value].JobNumber = jobNumber;
  dialogTPMVisible.value = false;
  changeInfo(requireList.value[rowIndexTPM.value]);
};


--> 数据源:
const TPMListInfo = computed(() => {
  console.log("data houduan: ", props.TPMGroups);
  return props.TPMGroups.map(item => {
    return {
      value: "",
      label: item.DepName,
      children: item.TPMList.map(t => {
        return {
          value: t.JobNumber,
          label: t.WorkerName + "/" + t.JobNumber,
          children: []
        };
      })
    };
  });
});
相关推荐
likangbinlxa3 小时前
【Oracle11g SQL详解】UPDATE 和 DELETE 操作的正确使用
数据库·sql
Ticnix3 小时前
ECharts初始化、销毁、resize 适配组件封装(含完整封装代码)
前端·echarts
纯爱掌门人3 小时前
终焉轮回里,藏着 AI 与人类的答案
前端·人工智能·aigc
twl3 小时前
OpenClaw 深度技术解析
前端
崔庆才丨静觅3 小时前
比官方便宜一半以上!Grok API 申请及使用
前端
星光不问赶路人4 小时前
vue3使用jsx语法详解
前端·vue.js
天蓝色的鱼鱼4 小时前
shadcn/ui,给你一个真正可控的UI组件库
前端
r i c k4 小时前
数据库系统学习笔记
数据库·笔记·学习
布列瑟农的星空4 小时前
前端都能看懂的Rust入门教程(三)——控制流语句
前端·后端·rust
Mr Xu_4 小时前
Vue 3 中计算属性的最佳实践:提升可读性、可维护性与性能
前端·javascript