当前位置: 首页 > news >正文

表单input 通过点击按钮新增input框(Vue3)

需求: 给label是车型的输入框后 加入新增按钮,label是车型的输入框本身禁用;新增新的输入框,并填写数据,将数据用,拼接起来给车型输入框

      <el-form id="carmodelMqsId" ref="formDataRef" :key="formKey" :model="formData" class="cncform" :rules="rules" label-width="200px">
        <el-row>
          <el-col :span="20">
            <el-form-item label="包含车型(整车编码前8位):" prop="IncludeCarModel" class="binding-class">
              <el-input v-model="formData.IncludeCarModel" disabled />
            </el-form-item>
          </el-col>
          <el-button style="margin-left: 5px" icon="Plus" circle @click="addNewPlant" />
          <span class="input-hint">只能使用"*"替代符</span>
        </el-row>
        <!-- 下面是输入框和 一个减号按钮 -->
        <el-row v-for="(item, index) in formData.formList" :key="index" style="margin-bottom: 8px">
          <el-col :span="12">
            <el-form-item label="" prop="" class="binding-class">
              <el-input v-model="item.carModelName" @input="updateIncludeCarModel" style="width: 90%" />
              <el-button v-if="formData.formList.length > 0" circle style="margin-left: 5px" icon="Remove" @click="removeField(index)" />
            </el-form-item>
          </el-col>
        </el-row>
</el-form>
<script setup>
import { reactive, ref, onMounted } from 'vue'

const formDataRef = ref(null)
const formData = reactive({
  no: '',
  carModelName: '',
  formList: [],
  IncludeCarModel: '', // 包含车型
  excludeCarModel: '', // 排除车型
  excludeList: [],
  editUser: '',
  editTime: ''
})

<script>

// 包含车型(整车编码前8位) 新增
const addNewPlant = () => {
  formData.formList.push({ carModelName: '' })
}

// 删除
const removeField = (index) => {
  formData.formList.splice(index, 1) // 删除指定索引的项
  updateIncludeCarModel()
}

// 展示数据的
const updateIncludeCarModel = () => {
  // 获取所有输入框中的值,按顺序合并为逗号分隔的字符串
  const carModels = formData.formList.map((item) => item.carModelName).filter((name) => name)
  formData.IncludeCarModel = carModels.join(',')
}

相关文章:

  • 锂电池保护板测试仪:电池安全的守护者与创新驱动力
  • 使用pinia存储登录用户的全部个人信息
  • React面试(一)
  • 数据库并发问题有那些以及解决办法
  • linux 系统 安装禅道教程
  • 策略模式环境类的实现方式对比
  • C++ Qt常见面试题(1):Qt信号槽的理解
  • 从零开始用react + tailwindcss + express + mongodb实现一个聊天程序(四) 实现注册功能
  • Conda 全面使用指南:从基础操作到高级优化
  • Storage Gateway:解锁企业混合云存储的智能钥匙
  • 最新版 (持续更新)docker 加速源 linux yum 源
  • ssh被暴力访问了,怎么拦截ip
  • (亲测有效)android studio gradle下载慢的解决方法
  • LangChain:Models、Prompts、Indexes、Memory、Chains、Agents。MaxKB
  • 《仙台有树》:未下毒道德逻辑题和修炼误解
  • MacPorts 创建自定义 Portfile 安装 RoadRunner
  • 清华大学《AIGC发展研究3.0》
  • 解决python项目无法安装openai模块的问题
  • GPT-5倒计时:2025年AI海啸来袭,机器与人类对话临近
  • 无人设备遥控器之视频回传篇
  • 北部艳阳高照、南部下冰雹,五一长假首日上海天气很“热闹”
  • 上海与世界|黄菊与上海建设中国式全球城市
  • 微软上财季净利增长18%:云业务增速环比提高,业绩指引高于预期
  • 荣盛发展股东所持1.17亿股将被司法拍卖,起拍价约1.788亿元
  • 十四届全国人大常委会举行第四十四次委员长会议
  • “女乘客遭顺风车深夜丢高速服务区”续:滴滴永久封禁两名涉事司机账号