以下代碼從/home.json URL獲取一些JSON數據,其中6個用戶包含5個微博。但是,只顯示最後4個標記(甚至不是第5個!!)。我花了2天的時間來發現錯誤,但不幸的是,我無法真正理解爲什麼這種方式不起作用。如果有人能幫助我,我會非常感激!Javascript只顯示最後的標記
我已經通過警報測試了所有的lon/lat變量!他們都有適當的數據。地圖應該是好的,因爲最後4個顯示!最有可能的問題在於我的閉包定義,但我真的不明白我在做什麼錯..
var GMAPS = window.GMAPS || {};
GMAPS.mainMap = function() {
var map;
var infowindow = new google.maps.InfoWindow();
var jsonObject = {};
function addMarkers() {
var xhr = new XMLHttpRequest();
xhr.open("GET", "/home.json", true);
xhr.onreadystatechange = function() {
if (xhr.readyState == 4 && xhr.status == 200) {
jsonObject = JSON.parse(xhr.responseText);
for (var i=0; i<jsonObject.length; i++) {
for (var j=0; j<jsonObject[i].microposts.length; j++) {
(function(Name, Title, Content, Latitude, Longitude) {
return function() {
//alert(Name + "\n" + Title + "\n" + Content + "\n" + Latitude + "\n" + Longitude + "\n"); //<-- this works!
var position = new google.maps.LatLng(Latitude, Longitude);
var contentString = "<h4>" + Name.bold() + "</h4>" + "<br />" + Title.bold()
+ "<br />" + Content;
var marker = new google.maps.Marker({
position: position,
title: Title,
map: map
});
google.maps.event.addListener(marker, 'click', (function(marker, contentString) {
return function() {
infowindow.setContent(contentString);
infowindow.open(map, marker);
}
})(marker, contentString));
};
})(jsonObject[i].name, jsonObject[i].microposts[j].title,
jsonObject[i].microposts[j].content,
jsonObject[i].microposts[j].lat,
jsonObject[i].microposts[j].lon)();
}
}
}
};
xhr.send(null);
}
function createMap() {
map = new google.maps.Map(document.getElementById('main_map'), {
zoom: 10,
panControl: true,
zoomControl: true,
zoomControlOptions: {
style: google.maps.ZoomControlStyle.SMALL
},
mapTypeControl: true,
scaleControl: true,
streetViewControl: true,
overviewMapControl: true,
scrollwheel: false,
center: new google.maps.LatLng(37.975327,23.728701),
mapTypeId: google.maps.MapTypeId.ROADMAP
});
}
function initAddress() {
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(showPosition);
}
else {
var position = new google.maps.LatLng(0, 0);
map.setCenter(position);
}
}
function showPosition(position) {
var position = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
map.setCenter(position);
}
return {
initMap : function() {
createMap();
initAddress();
addMarkers();
}
};
}();
document.addEventListener("DOMContentLoaded", GMAPS.mainMap.initMap, false);
謝謝你的回答喬。我有額外的parens爲了調用我的內部匿名函數。如果我刪除它們,則不顯示標記。不幸的是,你的解決方案不起作用(沒有標記顯示)。同樣,如果我添加額外的parens,只顯示最後4個標記。或許你可以解釋我做錯了什麼,以及根據你的建議採用了哪種邏輯?也許這將幫助我解決我的問題:-) – Filippos
如果你有一個地方我可以看到這個代碼執行...與實際數據,會更容易。 –
其實,你可以在這裏複製/粘貼jsonObject嗎? –