在 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>
相关推荐
北风toto15 小时前
为什么 IntelliJ IDEA Community 无法开发 Vue?——附解决方案
java·vue.js·intellij-idea
@PHARAOH15 小时前
HOW - 构建一个轻量前后端一体服务
前端·微服务·服务端
无限进步_16 小时前
【C++】C++11的类功能增强与STL变化
java·前端·数据结构·c++·后端·算法
一只小小Java16 小时前
Echarts单表多图实现
前端·javascript·echarts
跟着珅聪学java16 小时前
Element UI 的 Tabs 标签页开发教程
javascript·vue.js·elementui
dunky16 小时前
Spring AI 深度解析:把 LLM 抽象成 Spring Bean 的底层逻辑
前端
星栈16 小时前
Rust WASM 文件上传全链路:从浏览器到 S3,一个字节都不能少
前端·前端框架·开源
濮水大叔16 小时前
告别 Django Admin!这个 NodeJS 全栈框架让你在 DTO 中直接配置 Table/Form 渲染
前端·typescript·node.js
JarvanMo16 小时前
Flutter 3.44 & Dart 3.12重磅发布!这些新特性太香了
前端
竹林81816 小时前
用Viem替换ethers.js:一次合约交互的"减负"实战,我总算把TypeScript类型搞明白了
前端·javascript