vue2 elementui 封装一个动态表单复杂组件

封装一个动态表单组件在 Vue 2 和 Element UI 中需要考虑到表单字段的动态添加、删除以及验证等复杂功能。下面是一个简单的例子,展示如何创建一个可以动态添加和删除字段的表单组件。

首先,你需要安装并引入 Element UI:

bash

复制

npm install element-ui --save

然后,在你的 Vue 组件中引入 Element UI 的相关组件,并创建一个 DynamicForm.vue 组件:

复制代码
<template>
  <el-form :model="form" ref="dynamicForm" label-width="120px">
    <div v-for="(item, index) in formItems" :key="index">
      <el-form-item
        :label="item.label"
        :prop="`formItems[${index}].value`"
        :rules="item.rules"
      >
        <el-input v-if="item.type === 'text'" v-model="item.value"></el-input>
        <!-- 这里可以添加其他类型的输入组件,比如 el-select, el-date-picker 等 -->
      </el-form-item>
      <el-button type="danger" @click="removeField(index)">删除</el-button>
    </div>
    <el-button type="primary" @click="addField">添加字段</el-button>
    <el-form-item>
      <el-button type="primary" @click="submitForm">提交</el-button>
    </el-form-item>
  </el-form>
</template>

<script>
export default {
  name: 'DynamicForm',
  data() {
    return {
      form: {
        formItems: [], // 动态表单字段数组
      },
      fieldTypes: ['text'], // 可用的字段类型
    };
  },
  methods: {
    addField() {
      this.form.formItems.push({
        type: 'text', // 默认的字段类型
        label: '新字段',
        value: '',
        rules: [
          { required: true, message: '请输入值', trigger: 'blur' },
        ],
      });
    },
    removeField(index) {
      this.form.formItems.splice(index, 1);
    },
    submitForm() {
      this.$refs.dynamicForm.validate((valid) => {
        if (valid) {
          alert('提交成功!');
          // 在这里处理表单的提交逻辑,例如发送请求到后端
        } else {
          console.log('表单验证失败!');
          return false;
        }
      });
    },
  },
};
</script>

<style scoped>
/* 你可以在这里添加一些自定义的样式 */
</style>
相关推荐
陈随易9 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart10 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒12 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰13 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
山河木马13 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林81813 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花14 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu122714 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪15 小时前
Vue3-生命周期
前端
莪_幻尘15 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程