elementUI form表单动态增减表单项自定义校验规则

一、效果:

在这里插入图片描述

二、代码:

<template>
  <div class="seed_consume">
    <el-form :model="form" :rules="rules" ref="form">
      <div class="itemBox">
        <div class="titleBox">
          <div class="left">
            <span class="title">2、待返发卖贴(转让)消耗种子</span>
            <el-button
              type="text"
              style="margin-left:40px;"
              :disabled="form.forumSaleList.length >= 10"
              @click="add_rules('forumSaleList','1')"
            >添加规则</el-button>
          </div>
        </div>
        <div class="item" v-for="(item,index) in form.forumSaleList" :key="index">
          <div style="margin-top:10px;">发帖+转让次数范围</div>
          <div style="width:100%;display:flex;margin-top:10px;">
            <el-form-item :prop="'forumSaleList.'+index+'.timesMin'" :rules="rules.times">
              <el-input v-model="item.timesMin" style="width:100px;"></el-input>-
            </el-form-item>
            <el-form-item :prop="'forumSaleList.'+index+'.timesMax'" :rules="rules.times">
              <el-input v-model="item.timesMax" style="width:100px;"></el-input><el-button
                type="text"
                style="margin-left:40px;"
                @click="del_rules('forumSaleList',index)"
                v-if="index > 0"
              >删除</el-button>
            </el-form-item>
          </div>
          <div>
            <span>扣除种子数量</span>
            <el-button
              type="text"
              style="margin-left:40px;"
              @click="add_rules_item('forumSaleList','1',index)"
            >添加规则</el-button>
          </div>
          <div
            style="width:100%;display:flex;margin-top:10px;"
            v-for="(ite,idx) in form.forumSaleList[index].detailList"
            :key="idx"
          >
            <el-form-item
              :prop="`forumSaleList.${index}.detailList.${idx}.periodMin`"
              :rules="rules.detailList.period"
            >
              <span>待返期数在</span>
              <el-input v-model="ite.periodMin" style="width:100px;"></el-input>-
            </el-form-item>
            <el-form-item
              :prop="`forumSaleList.${index}.detailList.${idx}.periodMax`"
              :rules="rules.detailList.period"
            >
              <el-input v-model="ite.periodMax" style="width:100px;"></el-input>
              <span>期,扣除售价</span>
            </el-form-item>
            <el-form-item
              :prop="`forumSaleList.${index}.detailList.${idx}.amountRate`"
              :rules="rules.detailList.amountRate"
            >
              <el-input v-model="ite.amountRate" style="width:100px;"></el-input>
              <span>%的种子+扣除固定种子</span>
            </el-form-item>
            <el-form-item
              :prop="`forumSaleList.${index}.detailList.${idx}.seedQuantity`"
              :rules="rules.detailList.seedQuantity"
            >
              <el-input v-model="ite.seedQuantity" style="width:120px;"></el-input>
              <el-button
                type="text"
                style="margin-left:40px;"
                @click="del_rules_item('forumSaleList',index,idx)"
                v-if="idx > 0"
              >删除</el-button>
            </el-form-item>
          </div>
        </div>
      </div>
	</el-form>
    <div class="btnBox">
      <el-button type="primary" @click="submitForm('form')">保存</el-button>
    </div>
  </div>
</template>
<script>
export default {
  data() {
  	// 自定义校验规则
    const times = (rule, value, callback) => {
      let a = /^[1-9]\d*$/;
      if (value < 1 || value > 5000) {
        callback(new Error("值区间:1-5000"));
      } else if (!a.test(value)) {
        callback(new Error("整数"));
      } else {
        callback();
      }
    };
    const period = (rule, value, callback) => {
      let a = /^(\d+\.\d{1,1}|\d+)$/;
      if (value < 0.5 || value > 1000000) {
        callback(new Error("值区间:0.5-1000000"));
      } else if (!a.test(value)) {
        callback(new Error("最多保留1位小数"));
      } else {
        callback();
      }
    };
    const amountRate = (rule, value, callback) => {
      let a = /^\d+(.\d{1,2})?$/;
      if (value < 0 || value > 1000) {
        callback(new Error("值区间:0-1000"));
      } else if (!a.test(value)) {
        callback(new Error("最多保留2位小数"));
      } else {
        callback();
      }
    };
    const seedQuantity = (rule, value, callback) => {
      let a = /^[0-9]\d*$/;
      if (value < 0 || value > 10000) {
        callback(new Error("值区间:0-10000"));
      } else if (!a.test(value)) {
        callback(new Error("整数"));
      } else {
        callback();
      }
    };

    return {
      form: {
        title: "",
        forumSaleList: [
          {
            timesMin: "",
            timesMax: "",
            detailList: [
              {
                subType: "1",
                periodMin: "",
                periodMax: "",
                amountRate: "",
                seedQuantity: ""
              }
            ]
          }
        ],
      },
      rules: {
        times: { required: true, validator: times, trigger: "blur" },
        times5: { required: true, validator: times5, trigger: "blur" },
        detailList: {
          period: { required: true, validator: period, trigger: "blur" },
          amountRate: {
            required: true,
            validator: amountRate,
            trigger: "blur"
          },
          seedQuantity: {
            required: true,
            validator: seedQuantity,
            trigger: "blur"
          }
        },
      }
    };
  },
  created() {},
  methods: {
    // 保存
    submitForm(formName) {
      this.$refs[formName].validate(valid => {
        if (valid) {
          let form = this.form;
          console.log(form);
        } else {
          this.$message.error("请检查输入格式");
          return false;
        }
      });
    },
  }
};
</script>

前端进阶精选:点此去

### 回答1: 在ant Design中,我们可以使用Form组件和Form.Item组件来创建表单动态增减表单可以通过state来控制表单的数量,然后根据state中的值来渲染对应数量的表单。 首先,我们需要设置一个state来保存表单的数量,可以使用数组来保存每个表单的值,例如: ```javascript state = { formItems: [{ id: 1, value: '' }] }; ``` 然后,我们可以通过map函数来遍历表单的数组,动态生成对应数量的表单: ```javascript const { formItems } = this.state; {formItems.map(item => ( <Form.Item key={item.id}> {getFieldDecorator(`item-${item.id}`, { initialValue: item.value })(<Input />)} </Form.Item> ))} ``` 当需要增加或减少表单的数量时,我们可以通过点击按钮来触发对应的函数,例如增加表单的函数可以这样实现: ```javascript addFormItem = () => { const { formItems } = this.state; const newFormItem = { id: formItems.length + 1, value: '' }; this.setState({ formItems: [...formItems, newFormItem] }); } ``` 删除表单的函数可以这样实现: ```javascript removeFormItem = (id) => { const { formItems } = this.state; const newFormItems = formItems.filter(item => item.id !== id); this.setState({ formItems: newFormItems }); } ``` 在表单提交时,我们可以通过getFieldsValue函数获取到表单的值并进行提交操作: ```javascript handleSubmit = (e) => { e.preventDefault(); const { form, formItems } = this.props; form.validateFields((err, values) => { if (!err) { const formValues = Object.keys(values).reduce((result, key) => { const id = parseInt(key.split('-')[1]); const value = values[key]; const formItem = formItems.find(item => item.id === id); result.push({ id, value }); return result; }, []); console.log(formValues); // 进行提交操作 } }); } ``` 以上就是使用antd实现动态增减表单并设置表单回显的方法,通过动态管理state中的表单数组来动态渲染、增减表单,通过getFieldsValue函数获取表单的值并进行提交操作。 ### 回答2: Antd 是一款基于 React 的 UI 组件库,它提供了一系列易于使用和美观的表单组件。在使用 Antd 动态增减表单时,我们可以很容易地实现表单的设置和回显。 首先,我们可以使用 Antd 的 Form 组件来创建表单。在表单的设置方面,我们可以通过调用 Form 的 getFieldDecorator 方法来设置表单的初始值、校验规则和事件处理函数等。 接着,当需要动态增减表单时,我们可以利用 Antd 的 Button 组件来触发增减操作。通过在点击事件中操作表单数据(如数组的 push、splice 等方法),我们可以动态地添加或删除表单。 对于表单的回显,我们可以在表单初始化时将表单值设置为从后端获取的数据。这样,当我们动态增减表单后,原有的表单会自动填充之前的值。这个过程可以通过在 Form 组件的 initialValue 属性中设置从后端获取的数据来实现。 当用户提交表单时,我们可以通过调用 Antd 提供的 Form 的方法(如 validateFieldsAndScroll)来验证并获取表单数据。然后,我们可以将表单数据提交到后端进行处理。 总结起来,通过使用 Antd 提供的 Form 组件结合动态增减表单的操作,我们可以很方便地设置和回显表单。同时,借助 Antd 的其他组件和方法,我们还能够实现表单校验、事件处理和提交等功能。Antd 提供了一整套完善的表单解决方案,可供我们在各种场景中灵活使用。 ### 回答3: antd是一个非常流行的React UI组件库,提供了丰富的表单组件和功能。实现动态增减表单并设置表单回显有以下几个步骤: 1. 设置表单初始值:在使用antd表单组件时,可以通过`initialValues`属性设置表单的初始值。假设有一个列数据`list`,每个元素包含字段`name`和`value`,可以将其转化为初始值对象`initialValues`,其中每个字段的值对应表单的初始值。 2. 动态增减表单:通过antd提供的`Form.List`组件,可以实现多个表单动态增减。在表单中需要编辑和显示列数据时,可以使用`map()`方法循环渲染表单,并使用`remove()`方法删除不需要的表单。 3. 表单的读写绑定:在使用`Form.List`组件循环渲染表单时,可以使用`name`属性将每个表单与列数据的对应字段关联起来,实现读写绑定。这样,当表单的值发生变化时,列数据的对应字段值也会随之更新。 4. 表单回显:在设置表单初始值的基础上,antd的表单组件会自动将初始值回显到表单中,用户可以看到之前已经填写的内容。当删除或添加表单时,表单组件会自动处理表单的重新渲染和回显。 总结:通过设置表单初始值、使用`Form.List`组件实现动态增减表单表单的读写绑定以及antd的自动回显功能,可以实现antd动态增减表单并设置表单回显的需求。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值