My97DatePicker日期筛选 限制开始日期不能晚于结束日期;最大间距1年

方式一:直接利用控件属性——

         <%--开始日期不能晚于结束日期;最大间距1年--%>
            &nbsp;&nbsp;创建时间:<input id="FCreatedTimeBegin" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(1,'FCreatedTimeEnd');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', maxDate: '#F{$dp.$D(\'FCreatedTimeEnd\')||\'%y-%M-%d\'}',minDate:date})" class="txt txtSearch" />
            至:<input id="FCreatedTimeEnd" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(2,'FCreatedTimeBegin');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', minDate: '#F{$dp.$D(\'FCreatedTimeBegin\')}',maxDate:date})" class="txt txtSearch" />
            &nbsp;&nbsp;完成时间:<input id="FCompletedTimeBegin" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(1,'FCompletedTimeEnd');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', maxDate: '#F{$dp.$D(\'FCompletedTimeEnd\')||\'%y-%M-%d\'}',minDate:date})" class="txt txtSearch" />
            至:<input id="FCompletedTimeEnd" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(2,'FCompletedTimeBegin');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', minDate: '#F{$dp.$D(\'FCompletedTimeBegin\')}', maxDate:date})" class="txt txtSearch" />

方式二:自定义函数——

  &nbsp;&nbsp;创建时间:<input id="FCreatedTimeBegin" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(1,'FCreatedTimeEnd');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', maxDate: '#F{$dp.$D(\'FCreatedTimeEnd\')}',minDate:date})" class="txt txtSearch" />
            至:<input id="FCreatedTimeEnd" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(2,'FCreatedTimeBegin');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', minDate: '#F{$dp.$D(\'FCreatedTimeBegin\')}',maxDate:date})" class="txt txtSearch" />
            &nbsp;&nbsp;完成时间:<input id="FCompletedTimeBegin" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(1,'FCompletedTimeEnd');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', maxDate: '#F{$dp.$D(\'FCompletedTimeEnd\')}',minDate:date})" class="txt txtSearch" />
            至:<input id="FCompletedTimeEnd" runat="server" type="text" readonly="readonly" onfocus="var date=limitMonthDate(2,'FCompletedTimeBegin');WdatePicker({dateFmt:'yyyy-MM-dd',vel:'d244_2', minDate: '#F{$dp.$D(\'FCompletedTimeBegin\')}', maxDate:date})" class="txt txtSearch" />

 

/*CCM:控制时间控件间隔一年*/
function limitMonthDate(e, idname) {
    var DateString;
    if (e == 2) {
        var beginDate = $dp.$(idname).value;
        var time = new Date();
        var m = time.getMonth() + 1;
        var t = time.getFullYear() + "-" + m + "-" + time.getDate();
        if (beginDate != "" && beginDate != null) {
            var limitDate = new Date(beginDate);
            var years = limitDate.getFullYear() + 1;
            var months = limitDate.getMonth() + 1;
            var days = limitDate.getDate();
            DateString = years + '-' + months + '-' + days;
            return (Date.parse(t) < Date.parse(DateString)) ? t : DateString;
        } else {
            return t;
        }
    }
    if (e == 1) {
        var endDate = $dp.$(idname).value;
        if (endDate != "" && endDate != null) {
            var limitDate = new Date(endDate);
            var years = limitDate.getFullYear() - 1;
            var months = limitDate.getMonth() + 1;
            var days = limitDate.getDate();
            DateString = years + '-' + months + '-' + days;
            return DateString;
        }
    }
}

posted @   南极烧烤铺  阅读(1273)  评论(1编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示