在 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>
相关推荐
用户69371750013842 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦2 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013842 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水4 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫5 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll1236 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
用头发抵命6 小时前
Vue 3 中优雅地集成 Video.js 播放器:从组件封装到功能定制
开发语言·javascript·ecmascript
蓝冰凌7 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛7 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js