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>
相关推荐
孤水寒月3 小时前
基于HTML的悬窗可拖动记事本
前端·css·html
祝余呀3 小时前
html初学者第一天
前端·html
脑袋大大的4 小时前
JavaScript 性能优化实战:减少 DOM 操作引发的重排与重绘
开发语言·javascript·性能优化
速易达网络6 小时前
RuoYi、Vue CLI 和 uni-app 结合构建跨端全家桶方案
javascript·vue.js·低代码
耶啵奶膘6 小时前
uniapp+firstUI——上传视频组件fui-upload-video
前端·javascript·uni-app
JoJo_Way6 小时前
LeetCode三数之和-js题解
javascript·算法·leetcode
视频砖家6 小时前
移动端Html5播放器按钮变小的问题解决方法
前端·javascript·viewport功能
lyj1689977 小时前
vue-i18n+vscode+vue 多语言使用
前端·vue.js·vscode
小白变怪兽8 小时前
一、react18+项目初始化(vite)
前端·react.js
ai小鬼头8 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github