vue中使用elm表单的自定义校验规则

  data() {
    var checkAge = (rule, value, callback) => {
      // console.log(value, "输入的");
      // console.log(this.da, "最大的");
      // console.log(this.xiao, "最小的");
      let value1 = Number(value);
      let xiao1 = Number(this.xiao);
      let da1 = Number(this.da);
      if (value1 > da1 || value1 < xiao1) {
        return callback(new Error("请输入价格区间内的金额"));
      } else {
        callback();
      }
    };
    return {
      xiao: "",
      da: "",
      rules: {
        price: [
          {
            validator: checkAge,
            trigger: "blur"
          }
        ]
      }
    };
  },



   /* 保存编辑 */
    save(form) {
      this.$refs[form].validate(valid => {
        if (valid) {
          this.loading = true;
          let info = {
            appointment_record_id: this.form.id,
            type: 1,
            from: this.form.from,
            order_id: this.form.order_id,
            price: this.form.price
          };
          this.$http
            .post("admin-api/member-order/add", info)
            .then(res => {
              this.loading = false;
              console.log(res);
              if (res.data.status == 1) {
                this.$message({ type: "success", message: "成功" });
                this.form = {
                  type: 1,
                  from: 1
                };
                this.aaaainfo = "";
                this.updateVisible(false);
                this.$emit("done");
              } else {
                this.$message.error(res.data.error);
              }
            })
            .catch(e => {
              this.loading = false;
              this.$message.error(e.message);
            });
        } else {
          return false;
        }
      });
    },
对于ant-design-vue表单自定义校验规则,你可以使用Vue的"自定义校验器"来实现。下面是一个简单的示例: 1. 首先,你需要在Vue组件定义一个自定义校验器函数,该函数接收两个参数:rulevaluerule是当前校验规则的配置,value是当前表单字段的值。校验器函数需要返回一个Promise对象,通过resolve()来表示校验通过,通过reject()来表示校验失败。 ```javascript // 导入所需的校验规则 import { ValidationRule } from 'ant-design-vue/es/form/Form'; // 定义校验器函数 const customValidator = (rule, value) => { return new Promise((resolve, reject) => { // 自定义校验逻辑 if (value === 'custom') { resolve(); } else { reject(new Error('输入值不合法')); } }); }; ``` 2. 在表单项的rules属性使用自定义校验器函数。rules属性是一个数组,可以包含多个校验规则。在自定义校验规则,你可以使用ValidationRule对象提供的方法来定义校验规则的其他配置。 ```javascript <template> <a-form :form="form"> <a-form-item label="自定义校验"> <a-input v-decorator="['customField', { rules: [{ validator: customValidator }] }]"></a-input> </a-form-item> <!-- 其他表单项 --> <!-- ... --> </a-form> </template> <script> export default { data() { return { form: this.$form.createForm(this), }; }, }; </script> ``` 这样,当用户输入的值不等于'custom'时,校验器函数将返回一个带有错误信息的Promise对象,从而触发表单项的校验错误提示。 以上就是使用ant-design-vue实现表单自定义校验规则的方法。你可以根据自己的需要编写更复杂的校验逻辑,并在自定义校验器函数进行处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值