我使用Maps API v3 Places Autocomplete form
过去几个月用于我的项目,但是当我添加到另一个页面时,Places Autocomplete
无效。
我在这一行上收到错误:
for (var component in componentForm) {
document.getElementById(component).value = '';
document.getElementById(component).disabled = false;
}
并收到此错误消息:TypeError: document.getElementById(...) is null
以下是我的自动填充代码:
<script type='text/javascript'>
$(function(){
// This example displays an address form, using the autocomplete feature
// of the Google Places API to help users fill in the information.
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 initialize() {
// Create the autocomplete object, restricting the search
// to geographical location types.
autocomplete = new google.maps.places.Autocomplete(
/** @type {HTMLInputElement} */ (document.getElementById('autocomplete')), {
//types: ['geocode']
types: ['geocode', 'establishment']
});
// When the user selects an address from the dropdown,
// populate the address fields in the form.
google.maps.event.addListener(autocomplete, 'place_changed', function () {
fillInAddress();
});
}
// [START region_fillform]
function fillInAddress() {
// Get the place details from the autocomplete object.
var place = autocomplete.getPlace();
var formatted_address = place.formatted_address;
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 = new google.maps.LatLng(
position.coords.latitude, position.coords.longitude);
autocomplete.setBounds(new google.maps.LatLngBounds(geolocation, geolocation));
});
}
}
initialize();
// [END region_geolocation]
});
</script>
我的JSFiddle:http://jsfiddle.net/mananpatel/Ls2ag2p0/
任何想法?为什么它不起作用。
感谢。
答案 0 :(得分:0)
我认为您在尝试分配国家/地区时会获得空指针。尝试在国家/地区添加字段,例如
<div class="form-group">
<label class="control-label">Country</label>
<input type="text" name="country" id="country" value="" placeholder="" class="form-control" maxlength="15"/>
</div>
当我将其添加到您提交的JSFiddle时,它正常工作。