Я начинаю начинать с jQuery и пытаюсь прочитать данные из файла JSON и заполнить информацию (такую как координаты) на марке Google Maps.Заполнение маркеров Google Maps от JSON
Этот код работает нормально, но маркер не заполнен. Кто-нибудь может помочь мне разобраться с проблемой JSON?
$(document).on("pageinit", "#agents", function() {
var defaultLatLng = new google.maps.LatLng(-25.975769, 32.582499); // Default
if (navigator.geolocation) {
function success(pos) {
// Location found, show map with these coordinates
drawMap(new google.maps.LatLng(pos.coords.latitude, pos.coords.longitude));
}
function fail(error) {
drawMap(defaultLatLng); // Failed to find location, show default map
}
// Find the users current position. Cache the location for 5 minutes, timeout after 6 seconds
navigator.geolocation.getCurrentPosition(success, fail, {
maximumAge: 500000,
enableHighAccuracy: true,
timeout: 6000
});
} else {
drawMap(defaultLatLng); // No geolocation support, show default map
}
function drawMap(latlng) {
var myOptions = {
zoom: 10,
center: latlng,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById("map-canvas"), myOptions);
//READ FROM JSON
$.getJSON('data/agents.json', function (data) {
$.each(data.markers, function (i, marker) {
var marker = new google.maps.Marker({
position: Marker.LatLng(marker.latitude, marker.longitude),
map: map,
title: Marker.title(marker.latitude, marker.longitude),
});
}).click(function() {
$('#map-canvas').gmap('openInfoWindow', {
'address': marker.address
}, this);
});
});
JSON
{
"markers": [{
"latitude": -25.975769,
"longitude": 32.582499,
"title": "ACME Company",
"address": "my address 1"
}, {
"latitude": -25.977743,
"longitude": 32.579959,
"title": "XPTO Company",
"address": "my address 2"
}]
}
код как вывешено не действует javascript (функция 'drawMap' не закрыта и не является начальным' $ (document) .on ("pageinit" '). – geocodezip
что такое' Marker.title() '/'Marker.LatLng()'? –
I может скопировать его неправильно. В карте Google появляется сообщение bu t не маркеры. Latlng Я считаю, что это внутренняя функция API. – Andre