console.log nie pokazuje oczekiwanych właściwości obiektu
Mam następujący kod w javascript w mojej aplikacji node.js. Jednak niektóre obiekty nie są przechowywane w mojej zmiennejappointment
. Nawet jeśli je ustawię, gdy mam do nich bezpośredni dostęp, działa:console.log(appointment.test);
Co zrobiłem źle w tym kodzie?
var appointment = {
subscribed: false,
enoughAssis: false,
studentSlotsOpen: false
};
console.log(appointment);
for (var key in appointmentsDB[i]) {
appointment[key] = appointmentsDB[i][key];
}
appointment.test= "res";
console.log(appointment.test);
console.log(appointment);
Oto produkowana produkcja:
{ subscribed: false,
enoughAssis: false,
studentSlotsOpen: false }
res
{ comment: 'fsadsf',
room: 'dqfa',
reqAssi: 3,
maxStud: 20,
timeSlot: 8,
week: 31,
year: 2013,
day: 3,
_id: 51f957e1200cb0803f000001,
students: [],
assis: [] }
Zmiennaconsole.log(appointmentsDB[i])
wygląda jak:
{ comment: 'fsadsf',
room: 'dqfa',
reqAssi: 3,
maxStud: 20,
timeSlot: 8,
week: 31,
year: 2013,
day: 3,
_id: 51f957e1200cb0803f000001,
students: [],
assis: [] }
Następujące polecenie:
console.log(Object.getOwnPropertyNames(appointmentsDB[i]), Object.getOwnPropertyNames(Object.getPrototypeOf(appointmentsDB[i])));
Przedstawia:
[ '_activePaths',
'_events',
'errors',
'_maxListeners',
'_selected',
'_saveError',
'_posts',
'save',
'_pres',
'_validationError',
'_strictMode',
'isNew',
'_doc',
'_shardval' ] [ 'assis',
'timeSlot',
'db',
'_schema',
'id',
'base',
'day',
'collection',
'reqAssi',
'constructor',
'comment',
'year',
'room',
'students',
'week',
'_id',
'maxStud' ]
Spodziewałbym się jednak, że moje ostatnie wyjście zawiera również test wpisów, subskrybowany, wystarczającyAssis i studentSlotsOpen. Co jest nie tak w tym kodzie?
Rozwiązaniem, które znalazłem, było ręczne skopiowanie elementów, które chciałem.