2015-09-21 3 views
1

Я хочу отображать долготу и широту в поле ввода, используя адрес, который вводит пользователь. Я много искал и нашел некоторые решения, которые работают, когда я запускаю их на локальном сервере, и когда я включаю этот код в свой проект, тогда он не будет работать. Я использую тему Directory +. Эта тема имеет функцию отображения карты, и это дает мне ошибку.Как получить долготу и широту по адресу

Вы уже включили API Карт Google несколько раз на этой странице. Это может вызвать непредвиденные ошибки.

Вот мой код

var placeSearch, autocomplete; 
var componentForm = { 
    street_number: 'short_name', 
    route: 'long_name', 
    locality: 'long_name', 
    administrative_area_level_1: 'short_name', 
    country: 'long_name', 
    postal_code: 'short_name' 
}; 

function initAutocomplete() { 
    // Create the autocomplete object, restricting the search to geographical 
// location types. 
autocomplete = new google.maps.places.Autocomplete(
    /** @type {!HTMLInputElement} */ 
(document.getElementById('autocomplete')), 
    { types: ['geocode'] }); 

    // When the user selects an address from the dropdown, populate the address 
    // fields in the form. 
    autocomplete.addListener('place_changed', fillInAddress); 
} 

    // [START region_fillform] 
function fillInAddress() { 
    // Get the place details from the autocomplete object. 
    var place = autocomplete.getPlace(); 
    console.log(place); 
    alert(place.geometry.location); 
    for (var component in componentForm) { 
    document.getElementById(component).value = ''; 
    document.getElementById(component).disabled = false; 
} 

// Get each component of the address from the place details 
// and fill the corresponding field on the form. 
for (var i = 0; i < place.address_components.length; i++) { 
    var addressType = place.address_components[i].types[0]; 
    if (componentForm[addressType]) { 
    var val = place.address_components[i][componentForm[addressType]]; 
    document.getElementById(addressType).value = val; 
    } 
    } 
} 
// [END region_fillform] 

// [START region_geolocation] 
// Bias the autocomplete object to the user's geographical location, 
// as supplied by the browser's 'navigator.geolocation' object. 
function geolocate() { 
    if (navigator.geolocation) { 
    navigator.geolocation.getCurrentPosition(function(position) { 
    var geolocation = { 
     lat: position.coords.latitude, 
     lng: position.coords.longitude 
    }; 
    var circle = new google.maps.Circle({ 
     center: geolocation, 
     radius: position.coords.accuracy 
    }); 
    autocomplete.setBounds(circle.getBounds()); 
    }); 
} 
} 
// [END region_geolocation] 

</script> 
<script src="https://maps.googleapis.com/maps/api/js?signed_in=true&libraries=places&callback=initAutocomplete" 
    async defer></script> 

любезно скажите мне, где я не прав.

ответ

0

Я нашел исправление. Это была проблема с картиной google. Чтобы исправить это, я назвал свой код javascript после get_footer(); и его рабочий штраф.

Смежные вопросы