比较日期与循环和javascript

时间:2016-02-10 20:08:05

标签: javascript jquery json date compare

我需要用javascript比较日期,所以我写了一个函数:

function fulljson (){
    var db_data;
    $.ajax({
                url: "http://localhost:8888/auction/offers/5", 
                type: "GET",
                async: true, 
                dataType: "html",
                success: function(data) {
                var db_data = $.parseJSON(data);
                console.log(db_data);

    // declare variables
    var period_start = new Date('2016-02-24'),
        period_now = new Date();
        period_end = new Date('2016-11-01'),
        //current_date = period_start,
        array_of_all_dates = [];
console.log(period_start);
        var dodaj = parseInt('3');
        period_now = period_now.setDate(period_now.getDate() + dodaj);

        console.log(new Date(period_start).getTime() + ' i ' + period_now);

        if (new Date(period_start).getTime() > period_now){
            current_date = new Date(period_start);

        } else {
            current_date = new Date(period_now);
            current_date.setHours(1
                ,0,0,0);
        }

        //current_date = moment(current_date).format('YYYY-MM-DD');
        console.log(current_date);
    // Create a populated array of dates
   // Create a populated array of dates
    while (current_date.getTime() <= period_end.getTime()) {
      array_of_all_dates.push(current_date);
      current_date = new Date(+current_date);
      current_date.setDate(current_date.getDate() + 1);
    }

    // Now loop over the array of populated dates and mutate, so something like
    array_of_all_dates = array_of_all_dates.map(function (date) {
      var found_in_db = db_data.filter(function (db_data) {
        return new Date(db_data.start).getTime() === date.getTime(); // You need to do this comparison better!
      });
      if (found_in_db.length > 0) {
        return found_in_db[0];
      }
      var new_object = {
        title: '',
        start: date,
        price: '60'
      };
      console.log(new_object);
      return new_object;

    });



    console.log('result'+array_of_all_dates);
    drawCalendar(array_of_all_dates);
                }, 
                error: function (data) {
                console.log(data);
                console.log('GRESKA NEKA');
                }      
    });
        //end OF AJAX

};

我的ajax函数获取此数据:

[{"id":82,"price":61,"start":"Mon, 28 Mar 2016 00:00:00 +0000"},{"id":81,"price":61.5,"start":"Sun, 27 Mar 2016 00:00:00 +0000"},{"id":79,"price":61,"start":"Sun, 13 Mar 2016 00:00:00 +0000"},{"id":72,"price":61,"start":"Tue, 29 Mar 2016 00:00:00 +0000"},{"id":66,"price":61,"start":"Sat, 12 Mar 2016 00:00:00 +0000"},{"id":64,"price":60.5,"start":"Fri, 11 Mar 2016 00:00:00 +0000"}]

现在,我需要比较日期的功能仅适用于本案例中的2016年3月27日。

还是我的period_start is 24. Feb.period_end is 1.Nov.2016

为什么我的功能仅适用于27.March?

1 个答案:

答案 0 :(得分:1)

这是评论,但没有足够的空间,我想格式化它。

在代码中:

var period_start = new Date('2016-02-24'),
        period_now = new Date();  // <=== terminates statement
        period_end = new Date('2016-11-01'),
        //current_date = period_start,
        array_of_all_dates = [];

请注意,第二行以分号结束,因此 period_end array_of_all_dates 变为全局。这可能不是问题,但谁知道......

此外,ECMAScript 2015的当前解释是:

new Date('2016-02-24')

应为2016-02-24T00:00:00Z创建一个新日期,即它被视为UTC(与ISO 8601和标准本身不一致,因为日期和时间字符串没有时区如2016-02- 24T00:00:00被视为本地,但删除时间部分,它是UTC)。

接下来,

new Date()

创建本地* 日期,因此如果今天是2016-02-12那么:

new Date() != new Date('2016-02-12')

适用于偏移量不是00:00的所有时区,因为时间值会因时区偏移量而异。

我不清楚上述内容是否对您的代码产生严重影响,但自由混合UTC和本地日期并不是一个好主意。

接下来,我不明白使用:

var dodaj = parseInt('3');

而不是:

var dodaj = 3;

if (new Date(period_start).getTime() > period_now)

无缘无故地创建和丢弃Date对象,以下内容完全等效:

if (period_start > period_now)

它的好处在于它避免了IE中关于new Date(date)和两位数年份的一个模糊的错误。

哦,最后,2016年3月27日是许多地方daylight saving starts的星期日(例如意大利,虽然不是美国),所以也许夏令时会影响你的日期?

*其中“本地日期”表示根据主机的当前时区偏移设置调整时间值的日期。