Я пытаюсь использовать хеш-таблицу, поэтому я могу выбрать конкретный объект, хранящийся в массиве/объекте. Тем не менее, я столкнулся с проблемой, проходящей через объект.
var pins= {};
pins[6] = '6';
pins[7] = '7';
pins[8] = '8';
$('#result3').append('<div>Size: ' + Object.size(pins) + '</div>');
for(var i = 0; i < Object.size(pins); i++) {
$('#result3').append('<div>' + pins[i] + '</div>');
}
JSFiddle: http://jsfiddle.net/7TrSU/
Как вы можете видеть в TEST 3
, который использует объект pin
для хранения данных, я получаю undefined
при прохождении через объект pin
.
Каков правильный путь для цикла через pin
?
ИЗМЕНИТЬ
Что произойдет, если вместо pin[6] = '6'
я создам pin [6] = объект, и я хочу прокрутить все их свойства id
? Фактический фрагмент кода того, что я делаю...
for(var i = 0; i < json.length; i++) {
markerId = json[i].listing_id
// Place markers on map
var latLng = new google.maps.LatLng(json[i].lat, json[i].lng);
var marker = new google.maps.Marker({
listing_id: markerId,
position: latLng,
icon: base_url + 'images/template/markers/listing.png',
});
markers[markerId] = marker;
}
for(var marker in markers) {
console.log('marker ID: ' + marker.listing_id);
mc.addMarker(marker);
}
Возврат console.log
возвращает undefined, а если вместо console.log(marker)
я получаю значение marker.listing_id
. Извините, я смущаюсь!
Мне удалось заставить его работать с $.each(markers, function(i, marker){});
, но почему не работает for..in
?