element组件库系列(三)-- element-plus表单范围字段的校验

导读

这是element组件库系列文章,主要是平时使用element组件库的一些过程和心得,文章篇幅不定,有长有短,但主打一个实用(可能实用不一定是对你实用,不实用请轻喷)。废话少说,本篇将讲述element-plus中如何在表单(el-form)中对时间范围字段(分为开始时间和终止时间)进行校验的。

package version
element-plus 2.2.15
Vue3 3.3.4

正文

step1: 准备工作

搭建一个简易项目,引入element-plus

数据和表单代码为

vue 复制代码
    <script lang="ts" setup>
    const data = ref({
      name:'',
      age:'',
      cardType:'',
      cardId:"",
      cardStartTime:"",
      cardEndTime:""
    })
    </script>
    <template>
    <el-form ref="formRef" :model="data">
        <el-form-item label="姓名:" prop="name">
          <el-input v-model="data.name"></el-input>
        </el-form-item>
        <el-form-item label="年龄" prop="age">
          <el-input :min="0" type="number" v-model="data.age"></el-input>
        </el-form-item>
        <el-form-item label="证件有效期范围" :prop="['cardStartTime','cardEndTime']" :rules="[{
         validator:cardTimeValidator
        }]">
          <el-row>
            <el-col :span="11">
              <el-date-picker v-model="data.cardStartTime" type="date" clearable value-format="YYYY-MM-DD" :disabled-date="startDisabled"></el-date-picker>
            </el-col>
            <el-col :span="2">-</el-col>
            <el-col :span="11">
              <el-date-picker v-model="data.cardEndTime" type="date" clearable value-format="YYYY-MM-DD" :disabled-date="endDisabled"></el-date-picker>
            </el-col>
          </el-row>
        </el-form-item>
        <el-button type="primary" @click="handleValidate">验证表单</el-button>
      </el-form>
    </template>

step2 字段校验

由于,有效期范围通常是分为起始时间和终止时间。校验时,可能有以下情况:

  1. 起始时间和终止时间未填
  2. 起始时间未填,终止时间已填
  3. 起始时间已填,终止时间未填
  4. 起始时间晚于终止时间(或终止时间早于起始时间)
  5. 起始时间早于终止时间

很明显,最后一种情况才是对的。

为此,我使用自定义校验规则来实现这一功能。

vue 复制代码
    <script>
    function cardTimeValidator(rule,value,callback){
      if(!data.value.cardStartTime && !data.value.cardEndTime){
        callback('证件有效期不能为空')
      }
     if(!data.value.cardStartTime){
       callback(new Error('证件起始有效期不能为空'))
     }
      else if(!data.value.cardEndTime){
       callback(new Error('证件终止有效期不能为空'))
     } else{
        const stime = DayJS(data.value.cardStartTime);
        const etime =DayJS(data.value.cardEndTime);
        if(stime.isAfter(etime)){
          callback('起始时间不能晚于终止时间')
        } else if(etime.isBefore(stime)){
          callback('终止时间不能早于起始时间')
        } else{
          callback()
        }
     }
    }
    </script>
    <template>
    ...
    <el-form-item label="证件有效期范围" :prop="['cardStartTime','cardEndTime']" :rules="[{
         validator:cardTimeValidator
        }]">
          <el-row>
            <el-col :span="11">
              <el-date-picker v-model="data.cardStartTime" type="date" clearable value-format="YYYY-MM-DD" :disabled-date="startDisabled"></el-date-picker>
            </el-col>
            <el-col :span="2">-</el-col>
            <el-col :span="11">
              <el-date-picker v-model="data.cardEndTime" type="date" clearable value-format="YYYY-MM-DD" :disabled-date="endDisabled"></el-date-picker>
            </el-col>
          </el-row>
        </el-form-item>
    ...
    </template>

首先,在校验函数validator中,先判断起始时间和终止时间是否为空,再借助dayjsisBefore()isAfter()方法来比较日期,实现相应的判断逻辑。

除此之外,如果我们使用el-date-picker组件选择日期时,我们可以通过其disabled-date属性指定一个函数用于控制日期的可选状态

逻辑就是起始时间(终止时间)选中后,终止时间(起始时间)不能早于(晚于)起始时间(终止时间),否则就返回true表示禁用,这样,可以从数据输入阶段就杜绝起始时间晚于终止时间此类情况的出现。

总结

以上就是element-plus表单中时间范围字段如何校验的内容了,其它的范围字段的校验也同理,通过自定义的validator函数来解决,让我们下篇再见!

相关推荐
拉拉肥_King3 分钟前
Vue 3 主题切换深度解析:从炫酷动画到零闪烁方案
前端·vue.js
杨梦馨1 小时前
万级数据表格卡死?Web Worker 一招搞定
前端·javascript·vue.js
哈撒Ki4 小时前
快速入门vue3与常见面试题
前端·vue.js·面试
云水一下5 小时前
Vue.js从零到精通系列(一):初识Vue——背景、环境与第一个应用
前端·javascript·vue.js
云水一下5 小时前
Vue.js从零到精通系列(二):响应式核心——ref、reactive、computed与watch
前端·javascript·vue.js
卤蛋fg66 小时前
vxe-table 列拖拽排序与行拖拽排序:让表格布局任意排序
vue.js
粉末的沉淀6 小时前
vue:Vite项目中高效管理纯色SVG图标的方案
前端·javascript·vue.js
卤蛋fg66 小时前
vxe-table 列宽与行高拖拽调整:让表格布局极其灵活,拖拽功能非常强大
vue.js
向日的葵0067 小时前
Vue 路由传参的三种方式(三)
vue.js·路由
如果超人不会飞7 小时前
TinyVue Checkbox复选框组件使用指南
前端·vue.js