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>
相关推荐
米丘2 分钟前
Rollup 打包工具
前端
We་ct3 分钟前
LeetCode 74. 搜索二维矩阵:两种高效解题思路
前端·算法·leetcode·矩阵·typescript·二分查找
moneyinto3 分钟前
Three.js 必背核心方法
前端
wuhen_n6 分钟前
Vue3 组件中的图片懒加载与渐进式加载
前端·javascript·vue.js
叫回忆6 分钟前
elpis的npm抽离与发布
前端·javascript
wuhen_n13 分钟前
Vite 构建层面的图片优化:从压缩到转换
前端·javascript·vue.js
hashiqimiya14 分钟前
vue项目组装-路由-文件修改地方
前端·javascript·vue.js
回到原点的码农25 分钟前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
Mike_jia26 分钟前
ChatClaw:5 分钟打造你的个人 AI 智能体
前端
CodeSheep27 分钟前
王自如公开招聘01号员工,这要求有多离谱?
前端·后端·程序员