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

相关文章

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal