jeDate实现日期联动

开发中常有这样一种需求,有两个日期选择框,比如一个开航时间,一个回港时间,如下图所示:
在这里插入图片描述

我们知道,回港时间肯定是在开航时间后面的,也就是说,当用户选择了某一个开航时间后,回港时间能选择的最小值应该大于或等于开航时间;又或者用户选择了某一个回港时间后,开航时间能选择的最大值应该小于或者等于回港时间。即实现两个日期控件的联动。

本篇文章采用jeDate日期控件,来实现两个日期控件间的联动。

jeDate日期控件的基本使用,这里就不介绍了,下面直接上代码:

1.HTML页面
<div>
    <span>开航时间:</span>
    <input id="startTime" style="cursor: pointer;" placeholder="请选择" readonly/>

    <span>回港时间:</span>
    <input id="endTime" style="cursor: pointer;" placeholder="请选择" readonly/>
</div>
2.JS代码
jeDate('#startTime', link1);// 实例化开航时间
jeDate('#endTime', link2);// 实例化回港时间
$('#startTime').val(getNow());// 这里要注意,如果你需要控件初始化的时候就显示当前日期,最好不要使用jeDate自带的那个参数,因为如果你有重置或者说清空这些日期控件的操作,这个时候先选择回港时间会自动把开航时间赋值为今天

function link1(istg) {
    return {
        trigger: istg || "click",
        format: 'YYYY-MM-DD',
        //isinitVal: true,
        onClose: false,
        maxDate: function (obj) {
            var nowMinDate = jeDate.valText('#endTime') == "";
            return nowMinDate ? "2099-12-31" : jeDate.valText('#endTime');
        },
        donefun: function (obj) {
            jeDate("#endTime", link2(false));
        }
    };
}

function link2(istg) {
    return {
        trigger: istg || "click",
        format: 'YYYY-MM-DD',
        onClose: false,
        minDate: function (that) {
            var nowMinDate = jeDate.valText('#startTime') == "";
            return nowMinDate ? "1900-01-01" : jeDate.valText('#startTime');
        },
        donefun: function (obj) {
            jeDate("#startTime", link1(false));
        }
    };
}

// 获取今天的日期
function getNow() {
    var now = new Date();
    var year = now.getFullYear();
    var month = now.getMonth();
    var date = now.getDate();
    month = month + 1;
    if (month < 10) month = "0" + month;
    if (date < 10) date = "0" + date;
    return year + "-" + month + "-" + date;
}

上面需要初始化时间那里需要注意一下。

然后我们可以看出来,最主要的就是实例化日期控件中的 doneFun 函数,表示选中完日期后进行的回调,这里是去执行另外一个日期控件的初始化操作,然后通过获取前一个日期控件的时间来限定当前日期控件的可选范围。

效果:

在这里插入图片描述
在这里插入图片描述

可以看到,选择一个日期后,另外一个控件的可选范围已经变了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring MVC是一种基于Java的Web开发框架,它提供了一种简单而灵活的方式来构建Web应用程序。实现省市联动是指在前端页面上选择省份后,根据选择的省份动态加载对应的城市信息。 下面是一种实现省市联动的方法: 1. 在前端页面上,使用HTML的<select>标签创建一个下拉框,用于选择省份。例如: ```html <select id="province" onchange="loadCities()"> <option value="1">北京</option> <option value="2">上海</option> ... </select> ``` 2. 在JavaScript中,编写一个函数`loadCities()`,该函数会在选择省份后被调用。该函数通过Ajax请求向后端发送选择的省份信息,并接收后端返回的城市信息。例如: ```javascript function loadCities() { var provinceId = document.getElementById("province").value; var xhr = new XMLHttpRequest(); xhr.open("GET", "/getCities?provinceId=" + provinceId, true); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { var cities = JSON.parse(xhr.responseText); // 根据返回的城市信息更新城市下拉框 updateCities(cities); } }; xhr.send(); } ``` 3. 在后端,创建一个Controller处理`/getCities`的请求,并根据传入的省份ID查询对应的城市信息。例如: ```java @Controller public class CityController { @Autowired private CityService cityService; @GetMapping("/getCities") @ResponseBody public List<City> getCities(@RequestParam("provinceId") int provinceId) { return cityService.getCitiesByProvinceId(provinceId); } } ``` 4. 在CityService中,根据省份ID查询对应的城市信息。例如: ```java @Service public class CityService { @Autowired private CityRepository cityRepository; public List<City> getCitiesByProvinceId(int provinceId) { return cityRepository.findByProvinceId(provinceId); } } ``` 5. 在CityRepository中,定义查询方法,根据省份ID查询对应的城市信息。例如: ```java public interface CityRepository extends JpaRepository<City, Integer> { List<City> findByProvinceId(int provinceId); } ``` 这样,当选择省份时,前端页面会发送Ajax请求到后端,后端根据省份ID查询对应的城市信息,并将城市信息返回给前端,前端再根据返回的城市信息更新城市下拉框。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值