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

相关文章

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则