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 函数,表示选中完日期后进行的回调,这里是去执行另外一个日期控件的初始化操作,然后通过获取前一个日期控件的时间来限定当前日期控件的可选范围。

效果:

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值