Javascript:正在消失的对象属性

Javascript: disappearing object properties

本文关键字:对象 属性 消失 Javascript      更新时间:2024-04-01

我的问题是,我试图用数据数组填充对象,但其中一些数组要么设置不正确,要么消失了。

我试着寻找答案,但没有找到任何东西,我也试过调试,但一直未能找到问题的根源。

发生这种情况的函数是我一直在开发的一个自定义jQuery扩展,它将一个包含"小时"数组的对象作为输入:

Hour = {
  time: datetime,
  comment: string
};

代码如下:

(function ( $ ) {  
    $.fn.calendar = function(data){
    var times={};
    var debugging = {};
    var x = 0;
    data.hours.forEach(function(hour){
        //Transform hours.time into 1-7 day of the week
        //and 0-23 hour of the day
        //Save comments and timestamp to times[day][hour];
        var entry = new Date(hour.time);            
        var clockedTime = entry.toTimeString().match( /^([0-9]{2}:[0-9]{2}:[0-9]{2})/ )[0];
        times[entry.getDay()] = {};
        times[entry.getDay()][entry.getHours()] = [clockedTime, hour.comment];
        debugging[x] = [entry.getDay(), entry.getHours()];
        x++;
    });
    console.log(times);
    console.log(debugging);
    return this.html(times);
  };
}(jQuery));

控制台输出:

Object {1: Object, 2: Object, 3: Object, 4: Object}
Object {0: Array[2], 1: Array[2], 2: Array[2], 3: Array[2], 4: Array[2], 5: Array[2]}

因此,从输出中,我知道它在数据中循环了六次(因为调试对象包含六个项),但times对象只有四个条目。

任何帮助或建议都将不胜感激。

当您有重复的entry.getDay()值时,您正在覆盖您的属性。试试这个:

times[entry.getDay()] = times[entry.getDay()] || {};
times[entry.getDay()][entry.getHours()] = [clockedTime, hour.comment];

如果属性不存在,它将创建一个对象,如果存在,则将其保留。