gpt4 book ai didi

javascript - 有什么方法可以自定义 Google 的自动完成地址结果吗?

转载 作者:行者123 更新时间:2023-11-30 08:23:31 25 4
gpt4 key购买 nike

我想自定义自动建议结果。我想在结果顶部添加更多两个地址。是否可以使用 google api?为了更多的理解,我把我的应用程序屏幕贴在这里。我正在输入地址。它显示预测的地址,如何在结果顶部再添加 2 个地址。

enter image description here

最佳答案

您不能对 Autocomplete 类做很多事情,至少不能用任何记录的方法。您可以使用 Autocomplete Service类和 getPlacePredictions 方法来模仿标准自动完成的行为。

这意味着您将不得不构建自己的 UI 和行为,但它也使您可以更灵活地按照自己的方式设置样式,并且它将允许您添加自定义地址很容易。

这是一个简单的例子。它只是在顶部添加了两个自定义地址。您将必须实现 2 个自定义地址背后的逻辑,因为当前单击它们时不会发生任何事情。但这还不是最棘手的部分,这个示例已经展示了您可以用它做的很多事情。

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 with custom addresses
results.innerHTML += '<div class="pac-item custom"><span class="pac-icon pac-icon-marker"></span>My home address</div>';
results.innerHTML += '<div class="pac-item custom"><span class="pac-icon pac-icon-marker"></span>My work address</div>';

// 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() {

if (this.dataset.placeid) {
getPlaceDetails(this.dataset.placeid);
}
};
}
}

google.maps.event.addDomListener(window, 'load', initialize);
body,
html {
font-family: Arial, sans-serif;
padding: 0;
margin: 0;
height: 100%;
}

#map-canvas {
height: 130px;
margin-bottom: 10px;
}

table {
border-collapse: collapse;
margin-left: 20px;
}

table td {
padding: 3px 5px;
}

label {
display: inline-block;
width: 160px;
font-size: 11px;
color: #777;
}

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: 350px;
}

.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.custom {
background-color: #FFF9C4;
}

.pac-item:hover {
background-color: #efefef;
}

.pac-item-error,
.pac-item-error:hover {
color: #aaa;
padding: 0 5px;
cursor: default;
background-color: #fff;
}
<!-- Replace the value of the key parameter with your own API key. -->
<script src="//maps.googleapis.com/maps/api/js?libraries=places&key=AIzaSyCkUOdZ5y7hMm0yrcCQoCvLwzdM6M8s5qk"></script>

<div id="map-canvas"></div>
<table>
<tr>
<td>
<label for="address">Address:</label>
</td>
</tr>
<tr>
<td>
<input id="address" placeholder="Enter address" type="text" tabindex="1" />
</td>
</tr>
<tr>
<td colspan="2">
<div id="results" class="pac-container"></div>
</td>
</tr>
</table>

大部分代码都有注释,因此它应该不言自明。

JSFiddle demo

关于javascript - 有什么方法可以自定义 Google 的自动完成地址结果吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49671434/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com