iview 表单自定义校验规则

iview提供自定义校验规则,但做表单验证时可能会使用到组件中的响应式数据,配合自定义规则实现表单校验功能

html代码:

<Form  ref="formData" :model="formData" :rules="ruleValidate" >
     <FormItem  prop="date" label="选择时间" >         
         <DatePicker 
            v-model="formData.date"
            type="date"
            placeholder="请选择日期"            
         ></DatePicker>
      </FormItem> 
</Form>
vue组件中js中的代码:

data() {
    return {
       formData: {},
       //校验规则
       ruleValidate: { 
          // date绑定的html中的时间组件
          date: [
              {
                 // 日期改变时调用this.validateDate方法进行校验,此方法中可以使用响应式数据
                 validator: this.dateRule,
                 trigger: 'change'
              }
           ]
       }
    }
}
在methods中定义校验的方法:

methods: {
    dateRule(rule, value, callback) {
         // 注意:不管有没有校验规则,最后都要调用callback才会生效
         // 进行日期格式化
         let time = dateFormat(value, 'yyyy-MM-dd') 
         if (!value) {
             callback(new Error('请选择时间'))
         } else if (timeGroup.indexOf(time) > -1) {
             callback(new Error('选择的日期已存在'))
         } else {
             // 将得到的日期转化为秒,之后比较大小
             let currentTime = new Date(value).getTime()
             let timeGapList = []
             timeGroup.map(item => {
                 item = new Date(item).getTime()
                 timeGapList.push(item)
             })
             // 查找出数组中最大值最小值
             let max = Math.max.apply(null, timeGapList)
             let min = Math.min.apply(null, timeGapList)
             if (currentTime > min && currentTime < max) {
                 callback(new Error('不可选择中间日期,请重新选择日期'))
             }
         }
         // 最后要执行一下回调,不然不会触发校验
         callback()
    }
}

 

iview是一款基于Vue.js的UI组件库,提供了丰富的表格组件和表单校验功能。 在iview的表格组件中,可以使用表单校验功能来对每一行或特定列的数据进行校验。可以根据需要设置表格的rules属性来定义校验规则。 首先,我们需要定义校验规则,可以使用常见的校验规则例如required、max、min等,也可以定义自定义校验规则。每个校验规则都可以附加一条错误信息。 在表格的columns属性中,可以通过scopedSlots可以定义每一列的渲染方式。在scopedSlots中,我们可以使用iview提供的FormItem组件来实现表单校验功能。 具体实现步骤如下: 1. 在表格的columns属性中,为需要校验的列设置scopedSlots属性,并在scopedSlots中使用FormItem组件包裹需要校验表单元素。 2. 在FormItem组件中,可以使用prop属性来指定表单元素对应的字段名。同时,可以在FormItem组件中添加rules属性,指定对应的校验规则。 3. 在设置完校验规则后,可以通过v-model来与数据进行双向绑定。在校验不通过时,FormItem会自动显示错误信息。 通过以上步骤,我们就可以在iview的表格组件中实现表单校验功能。当用户在表格中输入数据时,会根据定义的校验规则进行实时校验,并在不通过时给出错误提示。 这样的表格内表单校验功能,可以帮助开发者更方便地对表格中的数据进行校验和验证,确保数据的准确性和完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值