DateTimePicker之禁用当前日期时间之前的数据以及校验函数

本文主要是介绍DateTimePicker之禁用当前日期时间之前的数据以及校验函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、禁用当前日期时间功能效果

dateTimePicker禁用当前日期时间

2、需要用到的属性

  1. disabledDate: 禁用日期。
  2. disabledTime: 禁用时间。

3、相关代码

fieldProps={{disabledDate(date) {return date && date < moment().startOf('day');},disabledTime: (date: any) => disabledTime(date),}}//相关函数-----------------------------/*** 根据传入参数生成一个数组* @param start 数组起始值* @param end 数组截止值*/const range = (start: number, end: number) => {const result = [];for (let i = start; i < end; i++) {result.push(i);}return result;};/*** dateTimePicker的禁用时间设置* @param dates 日期组件选中时间* @param disabledDate 禁用时间的起点,默认为当前时间* @param options { isNeedAddHour: 是否需要加小时,addHourNum:要加多少小时}*/const disabledTime = (dates: any,disabledDate = new Date(),options = {isNeedAddHour: false,addHourNum: 0,},) => {let curDate = disabledDate;let hours = curDate.getHours() + options.addHourNum;let minutes = curDate.getMinutes();let seconds = curDate.getSeconds();//获取选择的时间let selHours = moment(dates).hours();let selMinutes = moment(dates).minutes();if (dates && moment(dates).date() === moment().date()) {//判断选中的是当天return {disabledHours: () => range(0, hours), // 禁用当前小时之前的小时disabledMinutes: () => {if (selHours != null && selHours === hours) {//判断选中的是当前小时return range(0, minutes);}return [];},disabledSeconds: () => {if (selMinutes != null && selMinutes === minutes) {//  判断选中的是当前分钟return range(0, seconds);}return [];},};}return {disabledHours: () => [],disabledMinutes: () => [],disabledSeconds: () => [],};};

4、如果当前表单中有两个DateTimePicker,且后一个要根据前一个进行禁用、校验相关的配置的话

第二个组件的禁用、校验设置可以这么写

//禁用
fieldProps={{disabledDate(date) {// 没选择计划发车时间,就默认禁用今天之前的时间// 选择了就禁用planDate之前的时间let selectedPlanData =editFormRef.current.getFieldValue('planDate');return !!selectedPlanData? date &&date < moment(new Date(selectedPlanData)).startOf('day'): date && date < moment().startOf('day');},disabledTime: (date: any) => {let selectedPlanData =editFormRef.current.getFieldValue('planDate');return disabledTime(date,new Date(!!selectedPlanData ? selectedPlanData : null),{isNeedAddHour: true,addHourNum: 2,},);},
}}
// 校验
rules={[{validator(rule, value, callback) {let selectedPlanDate =editFormRef.current.getFieldValue('planDate');if (!value) {callback('不能为空');} else if (moment(value).isBefore(moment())) {return callback('时间不能小于当前时间');} else if (moment(value).isBefore(moment(selectedPlanDate))) {callback('时间不能小于计划发车时间');} else if (moment(value).isAfter(moment(selectedPlanDate)) &&moment(value).isBefore(moment(selectedPlanDate).add(2, 'hours'),)) {callback('至少大于计划发车时间两小时');} else {callback();}},},
]}

这篇关于DateTimePicker之禁用当前日期时间之前的数据以及校验函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/463263

相关文章

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

Go Mongox轻松实现MongoDB的时间字段自动填充

《GoMongox轻松实现MongoDB的时间字段自动填充》这篇文章主要为大家详细介绍了Go语言如何使用mongox库,在插入和更新数据时自动填充时间字段,从而提升开发效率并减少重复代码,需要的可以... 目录前言时间字段填充规则Mongox 的安装使用 Mongox 进行插入操作使用 Mongox 进行更

springboot日期格式化全局LocalDateTime详解

《springboot日期格式化全局LocalDateTime详解》文章主要分析了SpringBoot中ObjectMapper对象的序列化和反序列化过程,并具体探讨了日期格式化问题,通过分析Spri... 目录分析ObjectMapper与jsonSerializer结论自定义日期格式(全局)扩展利用配置

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言