表单参数绑定(如何解决一个输入框绑定两个参数)

表单参数绑定(如何解决一个输入框绑定两个参数)

在这里插入图片描述

问题复现

       <el-form-item label="会议编号" prop="meetingNum">
          <el-select v-model="form.meetingNum" placeholder="请选择会议编号" style="width: 100%;"
                     :disabled="form.electricalNum ? false : true">
            <el-option v-for="item in meetingNumList" :key="item.id" :label="item.consultationCode"
                       :value="item.consultationCode">
            </el-option>
          </el-select>
        </el-form-item>

现在我想绑定两个参数,form.meetingNum绑定id,还有一个form.userId绑定userId,怎么办呢?

问题解决

如果想将form.meetingNum绑定到id,并将form.userId绑定到userId,你可以通过修改el-option元素的value属性来实现这一点。具体来说,你可以将form.meetingNum的值设置为对象,其中包含iduserId属性。下面是一个示例:

<el-form-item label="会议编号" prop="meetingNum">
  <el-select v-model="form.meetingNum" placeholder="请选择会议编号" style="width: 100%;"
    :disabled="form.electricalNum ? false : true">
    <el-option v-for="item in meetingNumList" :key="item.id" :label="item.consultationCode"
      :value="{ id: item.id, userId: item.userId }">
    </el-option>
  </el-select>
</el-form-item>

在这个例子中,form.meetingNum将成为一个包含iduserId属性的对象。然后,你可以通过form.meetingNum.idform.meetingNum.userId来访问这两个值。

确保在处理提交表单或其他操作时,你了解form.meetingNum的结构,以便正确处理iduserId

但是,我不满意,我不想这样子来回换参数,那么,就稍微改变一下啦!

方案优化

另一种方法是使用计算属性(computed property)来处理这两个值的绑定。你可以在计算属性中将form.meetingNum拆分为iduserId。以下是一个例子:

<template>
  <el-form>
    <el-form-item label="会议编号" prop="meetingNum">
      <el-select v-model="selectedMeeting" placeholder="请选择会议编号" style="width: 100%;">
        <el-option v-for="item in meetingNumList" :key="item.id" :label="item.consultationCode" :value="item">
        </el-option>
      </el-select>
    </el-form-item>
  </el-form>
</template>

<script>
export default {
     
  data() {
     
    return {
     
      form: {
     
        userId: null, // Initialize userId with a default value if needed
      },
      meetingNumList: [
        // Your meeting number data here
      ],
    };
  },
  computed: {
     
    selectedMeeting: {
     
      get() {
     
        return this.form.meetingNum;
      },
      set(value) {
     
        this.form.meetingNum = value.id;
        this.form.userId = value.userId;
      },
    },
  },
};
</script>

在这个例子中,我们使用了计算属性selectedMeeting来处理form.meetingNum的获取和设置。当选择了一个会议编号时,set方法会将其拆分为iduserId,并分别设置到form.meetingNumform.userId中。这样,你可以维护一个更简洁的表单数据结构。

问题总结

当你想要将一个表单项(如form.meetingNum)与多个值关联时,有两种常见的方法:

  1. 使用对象作为值

    • el-optionvalue属性中,将form.meetingNum设置为一个对象,该对象包含需要关联的多个值,比如iduserId
    • 在后续代码中,通过form.meetingNum.idform.meetingNum.userId来访问这两个值。
    <el-option v-for="item in meetingNumList" :key="item.id" :label="item.consultationCode" :value="{ id: item.id, userId: item.userId }">
    </el-option>
    
  2. 使用计算属性进行处理

    • 使用计算属性,将form.meetingNum拆分为iduserId
    • el-select中,使用v-model绑定计算属性,使其更容易处理多个关联值。
    <el-select v-model="selectedMeeting" placeholder="请选择会议编号" style="width: 100%;">
      <el-option v-for="item in meetingNumList" :key="item.id" :label="item.consultationCode" :value="item">
      </el-option>
    </el-select>
    
    computed: {
         
      selectedMeeting: {
         
        get() {
         
          return this.form.meetingNum;
        },
        set(value) {
         
          this.form.meetingNum = value.id;
          this.form.userId = value.userId;
        },
      },
    },
    

选择哪种方法取决于你的偏好和代码的结构。第一种方法直接在el-option中处理值的结构,而第二种方法通过计算属性提供更灵活的处理方式,使得在后续的逻辑中可以更容易地操作这些值。

相关推荐

  1. SpringMVC参数

    2023-12-14 11:58:02       13 阅读
  2. vue输入

    2023-12-14 11:58:02       43 阅读
  3. Vue3-输入

    2023-12-14 11:58:02       21 阅读
  4. VUE3 输入

    2023-12-14 11:58:02       10 阅读
  5. Qt 遍历多按钮单击信号带参数一个

    2023-12-14 11:58:02       32 阅读
  6. 【Golang】 如何在 Gin 框架中多次参数

    2023-12-14 11:58:02       10 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-14 11:58:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-14 11:58:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-14 11:58:02       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-14 11:58:02       20 阅读

热门阅读

  1. 寻回初心:当初为什么学习计算机?

    2023-12-14 11:58:02       42 阅读
  2. SQL 算术运算符

    2023-12-14 11:58:02       41 阅读
  3. 36.@Import可以有几种用法?

    2023-12-14 11:58:02       58 阅读
  4. squid SSL https

    2023-12-14 11:58:02       30 阅读
  5. css做一条很细的分割线

    2023-12-14 11:58:02       42 阅读
  6. celery/schedules.py源码精读

    2023-12-14 11:58:02       38 阅读
  7. C语言第四十七弹---猜凶手

    2023-12-14 11:58:02       37 阅读
  8. Linux: 查看服务器的CPU信息

    2023-12-14 11:58:02       40 阅读
  9. Python 标准库SYS

    2023-12-14 11:58:02       36 阅读
  10. C++ 面向对象模型 小知识点

    2023-12-14 11:58:02       44 阅读