layui实现简单的酒店入住离店日历

2023-10-18 04:20

本文主要是介绍layui实现简单的酒店入住离店日历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本人新手一枚,写博客的目的是为了做记录,不喜勿喷,谢谢~。这是我做毕设时需要用到的一个小功能,功能较简单,代码较通俗。
效果图如下:
在这里插入图片描述

1. 引入layui的日期组件laydate,具体引入方法详见layui的官方文档。

注:上述地址,根据自己的项目情况而定。
var currentDate = formatDate(new Date());layui.use(['form','laydate'], function () {var laydate = layui.laydate;laydate.render({elem: '#in_and_out_date', type: 'datetime', range: ' 到 ', format: 'yyyy-MM-dd', theme: '#85ab00', min: currentDate // 限定可选日期为当前系统时间, btns: ['clear', 'confirm'], done: function (value, date) {...}, change: function (value, date) {// 选择时间,时间改变时console.log('你选择的日期是:' + value + '<br><br>获得的对象是' + JSON.stringify(date))}});});

效果图如下:
在这里插入图片描述

2. 在页面加载时,向后台发送请求,获得待改变文本的日期列表。我存入数据库的记录中包含一个时间范围,sql语句不再阐述,下述代码主要说明java获取指定时间范围内的所有日期。

/*** 生成XXXX-XX-XX ~ XXXX-XX-XX 天的,月/日 横坐标、默认值* @param preDateStre 起始日期* @param  endDateStr 终止日期* */private List<DateInfo> atteToDayList(String preDateStre,String endDateStr) throws  Exception{List<DateInfo>  toDayist = new ArrayList<DateInfo>();  //返回结果集// 把入住日期存入集合DateInfo dateInfo = new DateInfo();dateInfo.setDate(preDateStre);dateInfo.setInfo("无房");if (judgeDate(preDateStre)){toDayist.add(dateInfo);}while(!preDateStre.equals(endDateStr)){String dateStr = DateUtil.getNextDateStr(preDateStre);preDateStre = dateStr;DateInfo atd = new DateInfo();atd.setDate(dateStr);  //进行字符串切割,拼接成 如:01/02 的格式atd.setInfo("无房");if (judgeDate(dateStr)){toDayist.add(atd);}}return toDayist;}/*** 通过HashSet剔除list集合中的重复元素(无序)* @param dateInfos* @return*/private List<DateInfo> removeDuplicate(List<DateInfo> dateInfos) {Set<DateInfo> set = new HashSet<DateInfo>(dateInfos);// 清除原有的listdateInfos.clear();dateInfos.addAll(set);return dateInfos;}/*** 将待加入集合的日期与当前日期做比较,* 如果待加入日期小于当前日期,则不加入集合* 获得当前日期的时间戳、待比较日期的时间戳* 将当前日期的时间戳与待比较日期的时间戳相减* 如果值为负,则待比较日期大于当前日期,可以加入待返回集合,返回true* 如果值为正,则待比较日期小于当前日期,该日期可不加入待返回集合,返回false* @param date* @return*/private boolean judgeDate(String date) throws ParseException {// 获取当前日期Date currentDate = new Date();Long curValue = currentDate.getTime();SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Long comValue = sdf.parse(date).getTime();Long value = curValue-comValue;if (value<=0){return true;} else {return false;}}
DateUtil的getNextDateStr方法如下:**
/*** 计算参数日期的后一天,返回:2019-01-01* */public static String getNextDateStr(String currentDate) throws Exception {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Date date = sdf.parse(currentDate);Calendar c = Calendar.getInstance();c.setTime(date);c.add(Calendar.DAY_OF_MONTH,1);return sdf.format(c.getTime());}  

3. 前端接收后台传来的数据,主要代码如下:

var mark = {}; // mark是放置于layui组件mark属性的信息的
function getDateInfo(houseId) {var url = "../order/queryDate.do";$.ajax({"url": url,"type": "GET","data": "houseid=" + houseId,"dataType": "json","success": function (json) {// 根据返回的状态码对异常信息进行说明if (json.state == 200) {var data = json.data;for (var i=0;i<data.length;i++){// data[i].date是指后台传来的对象中的日期属性,我用一个类封装了日期和该日期包含的信息的mark[data[i].date]='<span style="color: red;">'+data[i].info+'</span>';}}},"error": function (xhr) {layer.msg("您还未登录,请先登录!");}});}

4. 将后台返回的数据添加到mark属性中,即可实现在指定日期自定义文本:

format: 'yyyy-MM-dd'
, theme: '#85ab00'
, min: currentDate // 限定可选日期为当前系统时间
mark: mark // 添加这个属性即可

效果图如下:
在这里插入图片描述

5. 实现选择“无房”日期弹出提示,代码如下:

			// 为layui日期组件添加时间,done是点击“确定”按钮触发的事件done: function (value, date) {var arr = value.split(" 到 ");var preTime = arr[0].substr(0, 11);var endTime = arr[1].substr(0, 11);console.log("arr: "+getDateRange(preTime,endTime));if (!getDateRange(preTime,endTime)){layer.msg("呀~你晚来了一步,你选择的日期范围中含有被预定的日期,换个日期吧~~~");$("#in_and_out_date").html("");return;}}, change: function (value, date) {// 选择时间,时间改变时console.log('你选择的日期是:' + value + '<br><br>获得的对象是' + JSON.stringify(date))}});// js根据时间范围获取所有日期/*获取传入的时间范围内的日期*/function getDateRange(preTime,endTime) {if (!preTime || !endTime){layer.msg("有时间为空");return false;}var ab = preTime.split('-');			// 把日期参数分割,注意,如果以'/'连接,则分割'/'var ae = endTime.split('-');var db = new Date();db.setUTCFullYear(ab[0], ab[1]-1, ab[2]);			// 返回符合UTC的时间格式var de = new Date();de.setUTCFullYear(ae[0], ae[1]-1, ae[2]);var unixDb = db.getTime();var unixDe = de.getTime();for(var k = unixDb; k <= unixDe;){// arr.push(timestampToTimeShort(k));debugger// 将时间范围内的时间戳转换成指定日期格式var time = timestampToTimeShort(k);// 判断该日期是否已经被预定if (mark.hasOwnProperty(time)){if (mark[time].indexOf("无房")){// 该房源被预定return false;}}k = k + 24 * 60 * 60 * 1000;}return true;}// 将时间戳转换为指定格式的时间function timestampToTimeShort(timestamp) {var date = new Date(timestamp); //时间戳为10位需*1000,时间戳为13位的话不需乘1000Y = date.getFullYear() + '-';M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';D = change(date.getDate()) + '';return Y + M + D;}

即可实现以下效果:
在这里插入图片描述
自定义mark标记,可参考以下博客:
http://www.cnblogs.com/qiuyueding/p/8296776.html
这是我第一次写博客,有什么考虑不周到的地方,请留言,我在以后的学习过程中慢慢改正。

这篇关于layui实现简单的酒店入住离店日历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库