Vue 学习随笔系列七 -- 表单动态生成

表单动态生成

文章目录

  • 表单动态生成
      • 1、动态表单组件封装
      • 2、组件引用
      • 3、实现效果


1、动态表单组件封装

<!-- 动态生成下拉框,可同理生成input框等 -->
<template>
  <el-dialog
    custom-class="custom-dialog"
    :title="dialogTitle"
    :visible.sync="visible"
    :close-on-click-modal="false"
    :close-on-press-escape="false"
    :before-close="handleClose"
    width="40%" 
  >
    <el-form 
      :model="form"
      ref="Form"
      label-width="80px"
    >
      <el-form-item
        v-for="(item, index) in formConfig"
        :key="index"
        :label="item.label"
      >
        <el-select
          clearable
          size="small"
          multiple
          v-model="formConfig[index].result.value"
          placeholder="请选择"
          style="width: 90%;"
          @change="val=>handelChange(val, index)"
          @clear="val =>handelClear(val, index)"
        >
        <el-option
          v-for="data in item.option"
          :key="data.code"
          :label="data.label"
          :value="data.code"
        >
        </el-option>
      </el-select>
      </el-form-item>

    </el-form>

    <div slot="footer" class="dialog-footer">
      <el-button size="small" @click="handleClose">取消</el-button>
      <el-button size="small" type="primary" @click="handleSubmit">确定</el-button>
    </div>

  </el-dialog>
  
</template>

<script>

  export default {
    data() {
      return {
        dialogTitle: "动态表单",
        visible: false,
        arr: [], // 回显参数
        form: {},
        formConfig: [
          {
            option: [
              {
                code: 1,
                label: '选项1'
              },
              {
                code: 2,
                label: '选项2'
              },
              {
                code: 3,
                label: '选项3'
              }
            ],
            result:{
              label:'',
              value:''
            }
          },
        ],
      }
    },
    // computed(){},
    methods: {
      // 打开弹窗
      handleOpen() {
        this.visible = true
      },
      // 关闭弹窗
      handleClose(){
        this.visible = false
      },
      handelChange(val,index){
        console.log("val==", val)
        if(val.length){//多选
          this.format2(val,index)
        } else {//单选
          this.format1(val,index)
        }                
      },
      // 清空多选框
      handelClear(val, index){
        if(!val){
          const newInitValue = this.formConfig.slice(0, index+1)
          this.formConfig = [...newInitValue]
          return
        }
      },
      //单选
      format1(val,index){
        if(!val){
          const newInitValue = this.formConfig.slice(0, index+1)
          this.formConfig = [...newInitValue]
          return
        }
        const label = this.formConfig[index].option.find(item=>item.code===val).label
        this.$set(this.formConfig[index],'result',{
          label,
          value: val
        })
        this.queryItems(index)
      },
      //多选
      format2(val, index){
        let label = []
        console.log("val.length", val)
        for(let i = 0; i< val.length; i++) {
          this.formConfig[index].option.find( item => {
            if(item.code === val[i]){
              label[i] = item.label
            }
          })
        }

        this.$set(this.formConfig[index], 'result', {
          label,
          value: val
        })
        const params = {index: index, code: val}
        this.getSonList(params)
      },
      //
      // queryItems(index){
      //   const temp = {
      //       option: [
      //         {
      //           code: 1,
      //           label: '选项1'
      //         },
      //         {
      //           code: 2,
      //           label: '选项2'
      //         },
      //         {
      //           code: 3,
      //           label: '选项3'
      //         }
      //       ],
      //       result:{
      //         label:'',
      //         value:''
      //       }
      //     }
      //   this.$set(this.formConfig, index+1, temp)
      // },
      handleSubmit() {
        const temp = this.formConfig.map(item=>item.result)
        let formParams = temp.slice(-2, -1) // 取数组倒数第二位值

        console.log(formParams)

        const params = formParams
        this.$emit('handleSubmit', params)
        this.handleClose()
      },
      // 获取一级科目
      // 获取一级科目
      getList(){
        console.log("getFirstList===")
        // getFirstList().then(res => {
        //   console.log('res===', res)
        //	 const temp = {
        // 		option: res.option,
        //		result: {
        //		label: "",
        //		value: "",
        //   }
        // 	 this.$set(this.formConfig, 0, temp) // 配置第一个下拉框选项
        // })
      },
      getSonList(value){
        console.log("getsonList====", value)
        // const params = {kmcode: value}
        // getsonLists(params).then(res => {
        //   console.log("res==", res)
        //	 const temp = {
        // 		option: res.option,
        //		result: {
        //		label: "",
        //		value: "",
        //   }
        // 	 this.$set(this.formConfig, index + 1, temp) // 配置后续下拉框选项
        // })
        let index = value.index
        // let code = value.code
        const temp = {
          option: [
            {
              code: 1,
              label: '选项1'
            },
            {
              code: 2,
              label: '选项2'
            },
            {
              code: 3,
              label: '选项3'
            }
          ],
          result:{
            label:'',
            value:''
          }
        }
        this.$set(this.formConfig, index+1, temp)
      }
    },
  }
</script>

2、组件引用

<template>
  <div class="main">
    <div class="form-box">
      <el-input
        v-model="value"
        clearable
        style="width: 20%;"
      ></el-input>
      <el-button type="primary" @click="handleOpen()">表单</el-button>
      <MultiForm ref="form" @handleSubmit="handleSubmit"></MultiForm>
    </div>     
  </div>
  
</template>

<script>
import MultiForm from "./multiSelect.vue"

export default {
  name: 'HelloWorld',
  components: {
    MultiForm
  },
  props: {

  },
  data(){
   return {
    value: '', // input输入框的值
   }     
  },
  mounted(){
  },
  methods: {
    handleOpen(){
      this.$refs.form.handleOpen()
    },
    handleSubmit(val){
      console.log("val==", val)
      let arr = val[0].label
      this.value = arr.toString()
    }
  }
}
</script>

<style>

</style>

3、实现效果

点击上一个选项,选中后出现下一个下拉框,并将最后一个数据回显到输入框中
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/241346.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux 使用定时任务

在Linux中&#xff0c;你可以使用cron&#xff08;定时任务管理器&#xff09;来设置和管理定时任务。以下是使用cron的基本步骤 编辑定时任务列表 打开终端&#xff0c;输入以下命令来编辑当前用户的定时任务列表 crontab -e如果是要编辑系统范围的定时任务&#xff0c;可以…

如何在忘记密码的情况下恢复解锁 iPhone

您忘记了 iPhone 密码吗&#xff1f;Apple 官方通常建议将 iPhone 恢复至出厂设置以将其删除。这种修复很不方便&#xff0c;甚至可能比问题本身更麻烦。 如果您也经历过同样的情况&#xff0c;并且想知道忘记了 iPhone 密码并且不想恢复它该怎么办&#xff0c;我们的终极指南…

docker基本管理和docker相关概念

docker是开源的的应用容器引擎&#xff0c;基于go语言开发的&#xff0c;运行在linux系统当中的开源的轻量级的"虚拟机。 docker的容器技术可以在一台主机上轻松的为任何应用创建一个轻量级的&#xff0c;可以移植的&#xff0c;自给自足的容器 docker的宿主机是linux系…

ElementPlus table 中嵌套 input 输入框

文章目录 需求分析 需求 vue3 项目中 使用UI组件库 ElementPlus 时&#xff0c;table 中嵌入 input输入框 分析 <template><div class"p-10"><el-table :data"tableData" border><el-table-column prop"date" label&qu…

jemeter,http cookie管理器

Http Cookie管理器自动实现Cookie关联的原理&#xff1a; (默认:作用域在同级别的组件) 一:当Jmeter第1次请求服务器的时候,如果说服务器有通过响应头的Set-Cookie有返回Cookie,那么Http Cookie管理器就会自动的保存这些Cookie的值。 二&#xff1a;当Jmeter第2-N次请求服务器的…

【同步FIFO_2023.12.13】

同步fifo&#xff0c;写时钟和读时钟为同一个时钟&#xff0c;用于交互数据缓冲 fifo的深度&#xff1a;同一块数据内存的大小 reg [2:0] Mem [8];//宽度3&#xff0c;深度8典型同步fifo的三部分 fifo写控制逻辑&#xff1a;写地址、写有效信号&#xff0c;fifo写满、写错等状…

ArkUI组件

目录 一、概述 声明式UI 应用模型 二、常用组件 1、Image&#xff1a;图片展示组件 示例 配置控制授权申请 2、Text&#xff1a;文本显示组件 示例 3、TextInput&#xff1a;文本输入组件 示例 4、Button&#xff1a;按钮组件 5、Slider&#xff1a;滑动条组件 …

Navicat 技术指引 | 适用于 GaussDB 分布式的数据查看器

Navicat Premium&#xff08;16.3.3 Windows 版或以上&#xff09;正式支持 GaussDB 分布式数据库。GaussDB 分布式模式更适合对系统可用性和数据处理能力要求较高的场景。Navicat 工具不仅提供可视化数据查看和编辑功能&#xff0c;还提供强大的高阶功能&#xff08;如模型、结…

【Git 小妙招】一文快速上手 Git 基本操作(两万字图文讲解)

文章目录 前言1. 创建 Git 本地仓库2. 配置 Git3. 认识工作区, 暂存区, 版本库3.1 添加文件(场景一)3.2 查看 .git 文件3.3 添加文件(场景二) 4. 修改文件5. 版本回退6. 撤销修改6.1 对于工作区的代码&#xff0c;还没有 add(场景一)6.2 已经 add &#xff0c;但没有 commit(场…

苹果电脑Python编辑开发软件pycharm pro 2023功能介绍

PyCharm Pro 2023是由JetBrains开发的一款专为Python开发者设计的跨平台集成开发环境&#xff08;IDE&#xff09;。它提供了丰富的功能和直观的用户界面&#xff0c;旨在提高在Mac平台上进行Python编程的效率。 PyCharm Pro 2023是PyCharm系列中的专业版&#xff0c;具有更多高…

D3846关键参数计算及设置方法D3846在电焊机产品中的作用是什么?

D3846是一块电流模式的PWM控制电路。 主要特点&#xff1a; ● 自动前馈补偿 ● 可编程控制的逐个脉冲限流功能 ● 推挽输出结构^ 下自动对称校正 ● 负载响应特性好 ● 可并联运行&#xff0c;适用于模块系统 ● 内置差动电流检测放大器&#xff0c; 共模输入范围宽 ● 双脉…

Linux高级管理--安装MySQL数据库系统

MySQL服务基础 MySQL.是一个真正的多线程、多用户的SQL数据库服务&#xff0c;凭借其高性能、高可靠和易于使 用的特性&#xff0c;成为服务器领域中最受欢迎的开源数据库系统。在2008年以前&#xff0c;MySOL项目由MySQL AB公司进行开发&#xff0c;发布和支持&#xff0c;之后…

查看mysql服务器的版本

在cmd下&#xff0c;可以使用命令mysql -V或者mysql --version查看mysql服务器的版本。例如&#xff1a; 如果已经登录mysql&#xff0c;可以使用命令show variables like version;来查询mysql服务器的版本。例如&#xff1a;

OpenAI Q* (Q Star)简单介绍

一、Q Star 名称由来 Q* 的两个可能来源如下&#xff1a; 1&#xff09;Q 可能是指 "Q-learning"&#xff0c;这是一种用于强化学习的机器学习算法。 Q 名称的由来*&#xff1a;把 "Q*"想象成超级智能机器人的昵称。 Q 的意思是这个机器人非常善于做决定…

串行计时芯片D1380/D1381,2.0V~5.5V 工作电流: 2V时 与TTL 兼容,采用DIP8、SOP8封装

D1380/D1381是一个带秒、分、时、日、日期、月、年的串行时钟保持芯片,每个月多少天以及闰年能自动调节, D1380/D1381低功耗工作方式, D1380/D1381用若干寄存器存储对应信息&#xff0c;一个32.768kHz 的晶振校准时钟&#xff0c;为了使用最小弓|脚&#xff0c;D1380/D1381使用…

PCIe在狂飙,SAS存储之路还有多远?

随着科技的飞速发展&#xff0c;固态硬盘&#xff08;SSD&#xff09;已经成为现代计算机系统中不可或缺的一部分。它以其出色的性能和可靠性&#xff0c;改变了我们对于存储设备的期待。当前业内SSD广泛应用&#xff0c;接口协议也有多样性&#xff0c;常见的SSD的接口协议归纳…

2024年风口最热门的项目,区块链技术重塑多个行业

区块链技术是一种基于去中心化、分布式、不可篡改的数据存储和传输技术&#xff0c;以链式数据结构为基础&#xff0c;通过密码学算法保证数据的安全性和不可篡改性。 以下是区块链技术的一些核心特点&#xff1a; 去中心化&#xff1a;区块链技术采用分布式架构&#xff0c;没…

5 转向事件驱动的架构

文章目录 核心概念消息代理事件和消息了解事件异步消息通信响应式系统 事件驱动的利弊消息传递模式发布—订阅工作队列过滤器数据持久性 消息传递代理协议、标准和工具AMQP和RabbitMQ基本概念交换类型和路由消息确认和拒绝 设置RabbitMQ安装RabbitMQRabbitMQ管理界面 Spring AM…

基于ssm大学生创新创业平台项目管理子系统设计与实现论文

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对大学生创新创业项目信息管理混乱&#xff0c;出错率高&#xff0c;信…

后台业务管理系统原型模板,Axure后台组件库(整套后台管理页面)

后台业务系统需要产品经理超强的逻辑思维能力和业务理解能力&#xff0c;整理了一批后台原型组件及完整的用 Axure 8 制作的后台系统页面&#xff0c;方便产品经理们快速上手制作后台原型。 包括交互元件、首页、商品、订单、库存、用户、促销、运营、内容、统计、财务、设置、…