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

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

问题复现

ini 复制代码
       <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属性。下面是一个示例:

ini 复制代码
<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。以下是一个例子:

xml 复制代码
<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来访问这两个值。
    ruby 复制代码
    <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绑定计算属性,使其更容易处理多个关联值。
    ruby 复制代码
    <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>
    kotlin 复制代码
    computed: {
      selectedMeeting: {
        get() {
          return this.form.meetingNum;
        },
        set(value) {
          this.form.meetingNum = value.id;
          this.form.userId = value.userId;
        },
      },
    },

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

相关推荐
weixin_524749964 分钟前
OkHttp 框架封装一个 HTTP 客户端,用于调用外部服务接口
java·后端
泉城老铁6 分钟前
Spring Boot 对接 Modbus 协议并获取点表数据的详细指南
java·后端·物联网
Frank_zhou25 分钟前
Spring初级容器初始化:加载XML的Document
后端
ClouGence44 分钟前
CloudCanal + Apache Paimon + StarRocks 实时构建湖仓一体架构
后端·数据挖掘·数据分析
Lorin洛林1 小时前
记一次解决 RestTemplate 和 HttpClient 请求结果乱码的问题
后端
星辰大海的精灵1 小时前
Spring 的替代方案:Micronaut
后端·架构
武子康1 小时前
Java-75 深入浅出 RPC Dubbo Java SPI机制详解:从JDK到Dubbo的插件式扩展
java·分布式·后端·spring·微服务·rpc·dubbo
Rabbb1 小时前
C# JSON 反序列化时,忽略转换失败的属性 JTokenSafeToExtensions
后端·c#·json
知其然亦知其所以然1 小时前
别再背八股了!面试说清 CMS 回收器,就靠这篇了
java·后端·面试