Javascript:正在消失的对象属性
Javascript: disappearing object properties
我的问题是,我试图用数据数组填充对象,但其中一些数组要么设置不正确,要么消失了。
我试着寻找答案,但没有找到任何东西,我也试过调试,但一直未能找到问题的根源。
发生这种情况的函数是我一直在开发的一个自定义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];
如果属性不存在,它将创建一个对象,如果存在,则将其保留。
相关文章:
- 如何从对象的原型方法访问JavaScript对象属性
- 如何将数组项添加到对象属性中
- 设置嵌套对象属性的更好方法
- JavaScript管理具有重复属性名称的对象属性
- 如何使用element.myobj.prop等具有对象属性的元素
- 如何使用(this)访问Angular 2 http rxjs catch函数中的对象属性
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何在AngularJS工厂中正确声明对象属性
- 如何使用object.assign()从其他对象引用基本对象属性
- 使用XPath样式访问Javascript JSON对象属性
- 将javascript对象(属性+值)合并到一个对象中
- 数组:使对象属性成为数组键
- 无法从JavaScript中的函数调用对象属性
- Google Closure Advanced |无法识别对象属性|动态属性
- Javascript从匿名函数访问外部对象属性
- 从函数更改对象属性
- 如何从字符串变量访问对象属性
- 从嵌套对象属性中获取排除某个值的最高值
- 在Aurelia computeds中,当设置依赖关系时,如何声明对对象属性的依赖关系
- 传递数量不确定的可能嵌套的对象属性