Как вызвать службу геокодирования google map с помощью jquery ajax
Я пытаюсь получить LatLng из google map geocode api. мой код ниже с адресными значениями - "Нью-Йорк, Нью-Йорк"
$.ajax({
url: 'http://maps.googleapis.com/maps/api/geocode/json',
data: {
sensor: false,
address: address
},
success: function (data) {
alert(data)
}
});
Но я не получаю никаких значений в оповещении.
Спасибо за любую помощь.
Ответы
Ответ 1
Вам нужно будет связаться с API в отношении правил.
$.getJSON( {
url : 'https://maps.googleapis.com/maps/api/geocode/json',
data : {
sensor : false,
address : address
},
success : function( data, textStatus ) {
console.log( textStatus, data );
}
} );
Edit:
Как немой я, не должен быть на stackoverflow утром! Проблема заключается в междоменном запросе. По соображениям безопасности это запрещено. См. Как сделать междоменные вызовы AJAX API Карт Google?
Пожалуйста, используйте Google Клиент геокодирования.
Ответ 2
нет необходимости использовать jquery, Google maps javascript API v3 имеет встроенные функции, которые упрощают использование API.
https://developers.google.com/maps/documentation/javascript/geocoding
https://developers.google.com/maps/documentation/geocoding/intro
var geocoder = new google.maps.Geocoder();
geocoder.geocode({ 'address': address }, function(results, status) {
if (status == google.maps.GeocoderStatus.OK) {
map.setCenter(results[0].geometry.location);
var marker = new google.maps.Marker({
map: map,
position: results[0].geometry.location
});
}
});
Ответ 3
V3 геокодирование webservice не поддерживает запросы JSONP, но все еще доступно в V2
Смотрите: http://blog.futtta.be/2010/04/09/no-more-jsonp-for-google-geocoding-webservice/
Ответ 4
Вот как я это сделал. Кажется, что геокодер создает собственный обратный вызов.
geo.geocode({ 'address': myaddress }, function(data, status) {
if (status == google.maps.GeocoderStatus.OK) {
var myylocation = data[0].geometry.location;
lat = myylocation.lat();
lng = myylocation.lng();
}
});
Ответ 5
Если кто-то ищет помощь по этой теме, вот как я это сделал. Обратите внимание, что это обратный поиск, но прямой поиск должен работать одинаково:
`
function getLocation() {
var latdegrees=40.2298;
var londegrees=-41.88754;
var url = "https://maps.googleapis.com/maps/api/geocode/json?latlng=" + latdegrees + "," + londegrees + "YOUR API KEY";
$.getJSON(url,function (data, textStatus) {
var streetaddress=data.results[0].formatted_address;
return streetaddress;
});
}`
Ответ 6
или указать dataType для jsonp?
$.ajax({
url: 'http://maps.googleapis.com/maps/api/geocode/json',
data: {
sensor: false,
address: address
},
dataType:'jsonp',
success: function (data) {
alert(data)
}
});