表单校验中自定义规则参数

表单校验中自定义规则与传参

elementUI 表单校验对输入框的值以传参形式限制长度

目的

业务代码中,经常会出现对表单输入框的值的长度进行限制,从而提升用户体验。

所以需要自定义校验规则,但如果输入框的长度限制都不相同,我们不能频繁去定义规则。

当然这并不只单独针对于长度的规则定义,只是以此为例,可以根据此例应对业务需要调整

定义校验规则JS文件

	// 输入长度校验
	
	export const strLength = (rule, value, callback) => {
	
	  if (!value) {
	    callback();
	  } else if (value.length > rule.strLength) {
	    callback(new Error(`此项最多可输入${rule.strLength}个字符`))
	  } else {
	    callback()
	  }
	
	}

可以看到在上述代码中,对校验的文本 value 的长度进行了判断,如果长度不足将会进行提示。
而我们校验的长度标准是取得的参数 rule.strLength

文件中使用

  1. 引入规则
	import { strLength } from "xxxxxxx";
  1. 在data中定义的表单校验规则中使用自定义方法
	export default {
	    name: "xxxxx",
	    data() {
	      return {
		      form:{
			      name:'',
		      },
		      rules:{
			      name:[
				      {
			              validator: strLength,
			              trigger: "blur",
			              strLength: 32
			          },
			      ]
		      }
	      }
	    }
	}

在上述 data 中的校验规则 rules 中可以看到,我们使用了自定义规则 strLength 的同时增加了一对“kv” strLength: 32 ,而它将会传递到我们的 JS规则文件中并可以通过形参 rule 拿到和使用,我们可以通过 console.log() 进行查看,如下:

	export const strLength = (rule, value, callback) => {
		console.log("rule========",rule)
		...... // 这里就是写你的规则逻辑
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于ant-design-vue表单自定义校验规则,你可以使用Vue的"自定义校验器"来实现。下面是一个简单的示例: 1. 首先,你需要在Vue组件定义一个自定义校验器函数,该函数接收两个参数rule和value。rule是当前校验规则的配置,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实现表单自定义校验规则的方法。你可以根据自己的需要编写更复杂的校验逻辑,并在自定义校验器函数进行处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值