在 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>
相关推荐
2501_9437823540 分钟前
【共创季稿事节】猜数字游戏:二分法思维与交互式反馈
前端·游戏·microsoft·harmonyos·鸿蒙·鸿蒙系统
GV191rLvq1 小时前
基于Socket实现的最简单的Web服务器【ASP.NET原理分析】
服务器·前端·asp.net
吠品1 小时前
LangChain 里 tool_call_id 为空?一次 MCP 工具集成的排查记录
前端
柒和远方1 小时前
Phase 7.4 学习博客:为什么多 API 项目需要 Swagger / OpenAPI
前端·后端·架构
张龙6871 小时前
拼多多开放平台对接踩坑实录:从 CLIENT_ID 配置到 MD5 签名算法的完整填坑指南
前端
GuWenyue1 小时前
提示词彻底过时?一套上下文工程方案,3步让LLM落地生产,代码直接复用
前端·javascript·人工智能
柒和远方2 小时前
Phase 7.3 复盘:后台任务不只是“扔进队列”,还要能被看见
前端·后端·架构
2501_943782352 小时前
【共创季稿事节】 倒计时器:时分秒选择器与定时器的协同工作
前端·华为·harmonyos·鸿蒙·鸿蒙系统
奶油mm2 小时前
公司技术债堆积如山,我一人之力用 Vue3 偷换了整个前端架构
前端·vue.js
用户938515635072 小时前
深入理解 JavaScript 中的 this 与数据存储的奥秘
前端·javascript