layui框架实战案例(25):laydate中mark的数据后端生成

2024-03-26 11:20

本文主要是介绍layui框架实战案例(25):laydate中mark的数据后端生成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mark,自定义日期标记。该属性是对 calendar 属性的进一步延伸,灵活度更高。属性可批量设置多个日期标记,如:

mark: {'0-10-14': '生日', //每年每月的某一天'0-0-10': '工资', // 每月 10 号'2008-8-8': '开幕', // 指定的日期
}

其中日期的格式必须是2008-8-8,而不能是2024-03-07,即当月份和天数是个位数时,不能用0补足。

场景描述

如在mysql数据库中遍历循环出对应的时间阶段,格式如何:

// 定义多组起始和结束日期
$datePairs = [['start' => '2023-03-12 08:00', 'end' => '2023-03-13 12:00'],['start' => '2023-03-16 08:00', 'end' => '2023-03-17 12:00'],['start' => '2023-03-19 08:00', 'end' => '2023-03-20 12:00'],['start' => '2023-04-01 09:00', 'end' => '2023-04-03 15:00'],
];

封装函数

function generateDateRanges($datePairs)
{//初始化最终合并的日期数组$mergedDateArray = [];//遍历每一组起始和结束日期foreach ($datePairs as $pair) {$startDateStr = $pair['start'];$endDateStr = $pair['end'];//创建DateTime对象$startDate = new DateTime($startDateStr);$endDate = new DateTime($endDateStr);//将起始日期的时间设置为午夜开始$startDate->setTime(0, 0, 0);//临时数组,用于存储当前日期对的日期范围$tempDateArray = [];//循环遍历当前日期对的日期范围$currentDate = clone $startDate; //克隆起始日期,以避免修改原始对象while ($currentDate <= $endDate) {//只添加日期部分(不包括时间)到临时数组中$tempDateArray[] = $currentDate->format('Y-n-j');//将当前日期增加一天$currentDate->modify('+1 day');}//将当前日期对的日期范围合并到最终数组中$mergedDateArray = array_merge($mergedDateArray, $tempDateArray);}//去除重复日期(如果需要)$mergedDateArray = array_unique($mergedDateArray);//按日期顺序排序(如果需要)sort($mergedDateArray);//转换日期格式,并生成你想要的输出格式$output = [];foreach ($mergedDateArray as $date) {$output[$date] = '';}//排序输出数组(如果需要)ksort($output);return $output;
}
  • 使用$currentDate->format(‘Y-n-j’)来格式化日期,其中Y代表四位数的年份,n代表不带前导零的月份,j代表不带前导零的天数。这样,输出的日期将不会包含任何前导零;

  • 运行上述代码将得到一个日期数组,其中的键是格式化为Y-n-j的日期字符串,值则是空字符串。如果想要包含其他的值,修改 r e s u l t [ result[ result[formattedDate] = ‘’;

  • 在遍历每个日期范围时,对$endDate使用了modify(‘+1 day’),这是因为DateTime对象在比较时是不包含结束日期那一天的。所以,人为地增加一天,以确保包含结束日期那天的数据。

  • 使用array_unique函数来去除数组中的重复日期(尽管在这个特定例子中由于我们按日期顺序添加,所以实际上不会有重复,但保留这一步可以作为一般性处理)。然后,使用sort函数对日期数组进行排序,确保输出结果是按日期顺序排列的。


@漏刻有时

这篇关于layui框架实战案例(25):laydate中mark的数据后端生成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

Java 中的 equals 和 hashCode 方法关系与正确重写实践案例

《Java中的equals和hashCode方法关系与正确重写实践案例》在Java中,equals和hashCode方法是Object类的核心方法,广泛用于对象比较和哈希集合(如HashMa... 目录一、背景与需求分析1.1 equals 和 hashCode 的背景1.2 需求分析1.3 技术挑战1.4