将Google地图搜索框与自动填充功能结合使用:
如果用户输入显示结果的名称,并在选择实际结果前按Enter键,则'places_matched'事件仍会触发,并且API会为其选择结果。
如何强制用户选择/突出显示自动填充结果,或者至少检测到他们实际上没有选择结果并阻止请求?
请在此处查看jsfiddle:http://jsfiddle.net/4rs1mgno/2/
在文本输入中输入任意内容,然后按Enter键。我键入'testing'并输出“BYU Testing Center”。我不想发生任何事情,因为他们实际上没有选择一个选项。
这是来自小提琴的JS代码:
$(function(){
var input = document.getElementById('pac-input');
var options = {
keyword: 'establishment'
}
var searchBox = new google.maps.places.SearchBox(input, options);
searchBox.addListener('places_changed', function(evt) {
console.log('changed');
var places = searchBox.getPlaces();
if (places.length == 0) {
return;
}
places.forEach(function(place) {
$('#output').append(place['name']);
});
});
});
谢谢!
这里有很多类似的问题,但没有一个与此相符。
答案 0 :(得分:6)
您可以使用Autocomplete Service和Places Service来模仿SearchBox的行为。使用getPlacePredictions
,您可以轻松控制搜索字段和搜索结果项的行为。
这个例子已经有了一些CSS,使它看起来像#34;喜欢" SearchBox。当然,你可以适应和增强。代码被评论,因此它应该说明一切。
var autocompleteService, placesService, results, map;
function initialize() {
results = document.getElementById('results');
var mapOptions = {
zoom: 5,
center: new google.maps.LatLng(50, 50)
};
map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
// Bind listener for address search
google.maps.event.addDomListener(document.getElementById('address'), 'input', function() {
results.style.display = 'block';
getPlacePredictions(document.getElementById('address').value);
});
// Show results when address field is focused (if not empty)
google.maps.event.addDomListener(document.getElementById('address'), 'focus', function() {
if (document.getElementById('address').value !== '') {
results.style.display = 'block';
getPlacePredictions(document.getElementById('address').value);
}
});
// Hide results when click occurs out of the results and inputs
google.maps.event.addDomListener(document, 'click', function(e) {
if ((e.target.parentElement.className !== 'pac-container') && (e.target.parentElement.className !== 'pac-item') && (e.target.tagName !== 'INPUT')) {
results.style.display = 'none';
}
});
autocompleteService = new google.maps.places.AutocompleteService();
placesService = new google.maps.places.PlacesService(map);
}
// Get place predictions
function getPlacePredictions(search) {
autocompleteService.getPlacePredictions({
input: search,
types: ['establishment', 'geocode']
}, callback);
}
// Get place details
function getPlaceDetails(placeId) {
var request = {
placeId: placeId
};
placesService.getDetails(request, function(place, status) {
if (status === google.maps.places.PlacesServiceStatus.OK) {
var center = place.geometry.location;
var marker = new google.maps.Marker({
position: center,
map: map
});
map.setCenter(center);
// Hide autocomplete results
results.style.display = 'none';
}
});
}
// Place search callback
function callback(predictions, status) {
// Empty results container
results.innerHTML = '';
// Place service status error
if (status != google.maps.places.PlacesServiceStatus.OK) {
results.innerHTML = '<div class="pac-item pac-item-error">Your search returned no result. Status: ' + status + '</div>';
return;
}
// Build output for each prediction
for (var i = 0, prediction; prediction = predictions[i]; i++) {
// Insert output in results container
results.innerHTML += '<div class="pac-item" data-placeid="' + prediction.place_id + '" data-name="' + prediction.terms[0].value + '"><span class="pac-icon pac-icon-marker"></span>' + prediction.description + '</div>';
}
var items = document.getElementsByClassName("pac-item");
// Results items click
for (var i = 0, item; item = items[i]; i++) {
item.onclick = function() {
getPlaceDetails(this.dataset.placeid);
};
}
}
google.maps.event.addDomListener(window, 'load', initialize);
&#13;
body,
html {
font-family: Arial, sans-serif;
padding: 0;
margin: 0;
height: 100%;
}
#map-canvas {
height: 150px;
width: 200px;
margin-bottom: 10px;
}
.search {
width: 200px;
padding: 5px;
float: left;
}
label {
display: block;
width: 160px;
font-size: 11px;
color: #777;
margin-bottom: 5px;
}
input {
border: 1px solid #ccc;
width: 170px;
padding: 3px 5px;
box-sizing: border-box;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-shadow: 0 2px 6px rgba(0, 0, 0, .1);
}
.pac-container {
background-color: #fff;
z-index: 1000;
border-radius: 2px;
font-size: 11px;
box-shadow: 0 2px 6px rgba(0, 0, 0, .3);
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
overflow: hidden;
width: 170px;
}
.pac-icon {
width: 15px;
height: 20px;
margin-right: 7px;
margin-top: 6px;
display: inline-block;
vertical-align: top;
background-image: url(https://maps.gstatic.com/mapfiles/api-3/images/autocomplete-icons.png);
background-size: 34px;
}
.pac-icon-marker {
background-position: -1px -161px;
}
.pac-item {
cursor: pointer;
padding: 0 4px;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
line-height: 30px;
vertical-align: middle;
text-align: left;
border-top: 1px solid #e6e6e6;
color: #999;
}
.pac-item:hover {
background-color: #efefef;
}
.pac-item-error,
.pac-item-error:hover {
color: #aaa;
padding: 0 5px;
cursor: default;
background-color: #fff;
}
&#13;
<div class="search">
<label for="address">Address:</label>
<input id="address" placeholder="Enter address" type="text" tabindex="1" />
<br />
<div id="results" class="pac-container"></div>
</div>
<div id="map-canvas"></div>
<script src="https://maps.googleapis.com/maps/api/js?libraries=places"></script>
&#13;
答案 1 :(得分:3)
如果用户按下输入,则不会发生任何事情。
编辑3:
$(function(){
var input = document.getElementById('pac-input');
var options = {
keyword: 'establishment'
}
var searchBox = new google.maps.places.Autocomplete(input, options);
google.maps.event.addListener(searchBox, 'place_changed', function () {
var place = searchBox.getPlace();
if(place.address_components != null && place.address_components.length >= 1){
console.log(place.address_components.length);
$('#output').append(place['name']);
}
});
});
&#13;
body {
font:14px sans-serif;
}
input {
margin: 0.6em 0.6em 0;
width:398px;
}
#map_canvas {
height: 400px;
width: 400px;
margin: 0.6em;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://maps.google.com/maps/api/js?libraries=places®ion=us&language=en&sensor=false"></script>
<input id="pac-input" type="text" size="50">
<div id="output"></div>
&#13;
答案 2 :(得分:2)
以下是解决方案的更新fiddle。知道每次在DOM树中本地有一个击键时,搜索框缓存最多5个结果后,这个想法很简单,直到你有一个匹配。它们缓存在div.pac-container
元素中。
$(function(){
var input = document.getElementById('pac-input');
var options = {
keyword: 'establishment'
}
var searchBox = new google.maps.places.SearchBox(input, options);
searchBox.addListener('places_changed', function(evt) {
var places = searchBox.getPlaces();
if ($('.pac-item').length > 0) {
return;
}
places.forEach(function(place) {
$('#output').append(place['name']);
});
});
});