在 Element Plus 中实现开始日期小于结束日期的验证

在 Element Plus 中实现开始日期小于结束日期的验证

html 复制代码
<template>
  <el-form :model="form" :rules="rules" ref="formRef" label-width="100px">
    <el-form-item label="开始日期" prop="startDate">
      <el-date-picker
        v-model="form.startDate"
        type="date"
        placeholder="选择开始日期"
        value-format="YYYY-MM-DD"
        :disabled-date="(date) => form.endDate && date > new Date(form.endDate)"
      />
    </el-form-item>
    
    <el-form-item label="结束日期" prop="endDate">
      <el-date-picker
        v-model="form.endDate"
        type="date"
        placeholder="选择结束日期"
        value-format="YYYY-MM-DD"
        :disabled-date="(date) => form.startDate && date < new Date(form.startDate)"
      />
    </el-form-item>
    
    <el-form-item>
      <el-button type="primary" @click="submitForm">提交</el-button>
      <el-button @click="resetForm">重置</el-button>
    </el-form-item>
  </el-form>
</template>

<script setup>
import { ref, reactive } from 'vue'
import { ElMessage } from 'element-plus'

const formRef = ref()
const form = reactive({
  startDate: '',
  endDate: ''
})

// 自定义验证规则
const validateStartDate = (rule, value, callback) => {
  if (!value) {
    callback(new Error('请选择开始日期'))
  } else if (form.endDate && new Date(value) > new Date(form.endDate)) {
    callback(new Error('开始日期不能晚于结束日期'))
  } else {
    callback()
  }
}

const validateEndDate = (rule, value, callback) => {
  if (!value) {
    callback(new Error('请选择结束日期'))
  } else if (form.startDate && new Date(value) < new Date(form.startDate)) {
    callback(new Error('结束日期不能早于开始日期'))
  } else {
    callback()
  }
}

const rules = {
  startDate: [
    { required: true, validator: validateStartDate, trigger: 'change' }
  ],
  endDate: [
    { required: true, validator: validateEndDate, trigger: 'change' }
  ]
}

const submitForm = async () => {
  if (!formRef.value) return
  
  try {
    await formRef.value.validate()
    ElMessage.success('验证通过!')
    console.log('表单数据:', form)
    // 提交逻辑
  } catch (error) {
    ElMessage.error('请检查表单填写是否正确')
  }
}

const resetForm = () => {
  if (!formRef.value) return
  formRef.value.resetFields()
}
</script>

<style scoped>
.el-date-picker {
  width: 100%;
}
</style>
相关推荐
王林不想说话5 小时前
提升工作效率的Utils
前端·javascript·typescript
weixin_584121435 小时前
vue内i18n国际化移动端引入及使用
前端·javascript·vue.js
Delroy5 小时前
一个不懂MCP的开发使用vibe coding开发一个MCP
前端·后端·vibecoding
imkaifan5 小时前
bind函数--修改this指向,返回一个函数
开发语言·前端·javascript·bind函数
xkxnq6 小时前
第一阶段:Vue 基础入门(第 7 天)
前端·javascript·vue.js
光头闪亮亮6 小时前
企业协同办公系统(OA)-【图标选择器】模块开发详解
前端·javascript·vue.js
pas1366 小时前
22-mini-vue props
前端·javascript·vue.js
pas1366 小时前
23-mini-vue 实现 emit 功能
前端·javascript·vue.js
百度地图汽车版6 小时前
【智图译站】基于 LightGBM 与 GNSS 多特征驱动的 NLOS 误差可靠识别方法
前端
黛色正浓6 小时前
leetCode-热题100-子串合集(JavaScript)
javascript·算法·leetcode