目前,当你点击位置字段中的autosuggest建议时,它只是将其加载到输入框中。我想对它进行调整,所以当你点击autosuggest框中的结果时,它不仅会将其值加载到输入框中,而且还会触发地理编码。我不知道如何做到这一点,所以我会感激一些帮助。
这是代码:http://jsfiddle.net/njDvn/130/
<!-- Geocode -->
$(document).ready(function () {
var GeoCoded = { done: false };
autosuggest();
$('#myform').on('submit', function (e) {
if (GeoCoded.done) return true;
e.preventDefault();
var geocoder = new google.maps.Geocoder();
var address = document.getElementById('location').value;
$('#myform input[type="submit"]').attr('disabled', true);
geocoder.geocode({
'address': address
},
function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
var latLng = results[0].geometry.location;
$('#lat').val(results[0].geometry.location.lat());
$('#lng').val(results[0].geometry.location.lng());
GeoCoded.done = true;
$('#myform').submit();
} else {
console.log("Geocode failed: " + status);
//enable the submit button
$('#myform input[type="submit"]').attr('disabled', false);
}
});
});
});
autosuggest:
<!-- AutoSuggest -->
function autosuggest() {
var input = document.getElementById('location');
var options = {
types: [],
};
var autocomplete = new google.maps.places.Autocomplete(input, options);
}
答案 0 :(得分:2)
您可以做的只是使用Places API库,只需在此示例中监听place_changed
事件:
https://developers.google.com/maps/documentation/javascript/places#getting_place_information
您可以使用以下代码获取地理编码:place.geometry.location