查找最近的日期(javascript)

时间:2014-04-01 09:08:26

标签: javascript jquery html date datetime

我想从xml找到距离日期最近的日期。

 <?xml version="1.0" encoding="UTF-8"?>
    <schedule>
    <layout fromdt="2014-01-01 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-02-01 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-03-01 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-04-05 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-04-01 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-05-01 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-02-01 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-02-21 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-04-21 00:00:00" todt="2014-01-01 05:30:00"/>
    <layout fromdt="2014-04-10 00:00:00" todt="2014-01-01 05:30:00"/>
    </schedule>

我尝试过使用默认日期格式&#34; Wed Dec 04 2013 14:50:17 GMT-0800(太平洋夏令时)&#34; 这项工作正确..

var ScheduleDate=[];
    XmlResponse=function(xmlHttpRequest, status)
    {   
        ScheduleDate=[];
        $(xmlHttpRequest.responseXML)
        {
            var today=new Date();
            var xml=xmlHttpRequest.responseXML;
            $(xml).find("layout").each(function()
            {
            var fromDate=new Date($(this).attr('fromdt'));
            var toDate=new Date($(this).attr('to'));

            if(toDate>=today )
            {
                ScheduleDate.push({"from":fromDate,"to":toDate});
            }

            });
        }
        console.log(ScheduleDate);
        dateFunction();
    }
    function closestTime(days, testDate,property)
    {
        var bestDiff = null;
        var bestDate = 0;
        for(i = 0; i < days.length; ++i){
            currDiff = days[i][property] - testDate;
             if((currDiff < bestDiff || bestDiff == null)&& currDiff > 0){
                bestDate = days[i][property];
                bestDiff = currDiff;
            } else if (currDiff == bestDiff && days[i][property] > testDate) {
                //alert(i);
                bestDiff = currDiff;             
            }
        }

        return bestDate;
    }
function dateFunction()
    {
        var closestFrom=closestTime(ScheduleDate, new Date(),"from");

}

但是当我尝试使用这种格式&#34; YYYY-MM-DD HH:MM:SS &#34;它返回无效日期..

var fromDate=new Date("2014-01-01 00:00:00");

那么我怎么能以日期格式或替代解决方案来获取此输入..

3 个答案:

答案 0 :(得分:1)

2014-01-01 00:00:00不是标准格式的有效格式。

我猜您正在使用Firefox,new Date("2014-01-01 00:00:00")仅适用于V8 JS引擎(Chrome),您可以使用某些替代库,例如Moment.js,然后它可以在所有平台上运行。

例如

var fromDate = moment("2014-01-01 00:00:00", "YYYY-MM-DD HH:mm:ss").toDate();

答案 1 :(得分:0)

对于那种格式化日期,您不需要第三方库。

使用内置函数Date.parse

某些浏览器(如Firefox)不支持给定格式,但您可以将其转换为ISO-8601)

var datestr = "2014-01-01 00:00:00";
var fromDate = new Date(Date.parse(datestr.replace(/ /, "T")));

在您的代码中,您可以使用以下方法:

var datestr = $(this).attr('fromdt');
var fromDate = new Date(Date.parse(datestr.replace(/ /, "T")));

Mozilla MDN上的函数文档:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/parse

答案 2 :(得分:0)

您可以使用Date.parse,但此函数会在Firefox中返回NaN,因此您必须手动设置Date,具体如下:

function getDateByString(dateString) {
    var date = dateString.split(" ")[0]
    var time = dateString.split(" ")[1]

    var dd = date.split("-")[0]
    var mm = date.split("-")[1]
    var yyyy = date.split("-")[2]

    var hh = time.split(":")[0] 
    var mi = time.split(":")[1]
    var ss = time.split(":")[2]

    return new Date(dd, mm, yyyy, hh, mi, ss);
}

新的Fiddle测试。