谷歌地图api place_changed事件不是射击
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了谷歌地图api place_changed事件不是射击相关的知识,希望对你有一定的参考价值。
我在我的ASP.NET MVC项目中使用谷歌地图API v3。 我想向用户显示一个地图,可以在其上搜索某个地方,然后选择该地点,然后提交(非常简单)。 在这种情况下一切正常,除了在用户在地图搜索框中键入时获取建议的位置。 以下是我添加google地图API的方法
<script src="https://maps.googleapis.com/maps/api/js?key=Correct_Key_Dot_Worry&libraries=places&callback=initMap" async defer></script>
<body>
<input id="pac-input" class="controls" type="text" placeholder="Search Box">
<input type="button" value="hakam" id="btntest" />
<div id="map" style="width:500px; height:500px; margin-top:400px"></div>
</body>
window.initMap = function(){
var map = new google.maps.Map(document.getElementById('map'), {
center: { lat: -33.8688, lng: 151.2195 },
zoom: 13
});
var input = (document.getElementById('pac-input'));
map.controls[google.maps.ControlPosition.TOP_LEFT].push(input);
var autocomplete = new google.maps.places.Autocomplete(input);
autocomplete.bindTo('bounds', map);
var infowindow = new google.maps.InfoWindow();
var marker = new google.maps.Marker({
map: map,
anchorPoint: new google.maps.Point(0, -29)
});
google.maps.event.addListener(autocomplete, 'place_changed', function () {
infowindow.close();
marker.setVisible(false);
var place = autocomplete.getPlace();
if (!place.geometry) {
window.alert("Autocomplete's returned place contains no geometry");
return;
}
// If the place has a geometry, then present it on a map.
if (place.geometry.viewport) {
map.fitBounds(place.geometry.viewport);
} else {
map.setCenter(place.geometry.location);
map.setZoom(17); // Why 17? Because it looks good.
}
marker.setIcon(({
url: place.icon,
size: new google.maps.Size(71, 71),
origin: new google.maps.Point(0, 0),
anchor: new google.maps.Point(17, 34),
scaledSize: new google.maps.Size(35, 35)
}));
marker.setPosition(place.geometry.location);
marker.setVisible(true);
var address = '';
if (place.address_components) {
address = [
(place.address_components[0] && place.address_components[0].short_name || ''),
(place.address_components[1] && place.address_components[1].short_name || ''),
(place.address_components[2] && place.address_components[2].short_name || '')
].join(' ');
}
//infowindow.setContent('<div><strong>' + place.name + '</strong><br>' + address);
infowindow.setContent('<div><strong>' + "Location(" + place.geometry.location.lat() + "," + place.geometry.location.lng() + ")" + '</strong><br>');
infowindow.open(map, marker);
});
}
问题
place_changed
的处理程序没有触发,当我开始在google地图搜索的文本框内写入时,不会调用处理程序的代码。
经过大约6个小时的搜索和思维旋转,我阅读了关于此事件的google maps API文档,如下所示
当PlaceResult可用于用户选择的地方时,将触发此事件。如果用户输入控件未建议的Place的名称并按Enter键,或者Place detail请求失败,则会触发place_changed事件,该事件包含name属性中的用户输入,没有其他属性定义。
正如文档所说的那样,当我点击“输入”键时,我真的让这个事件place_changed
触发,再次,正如文档所说,我得到了包含用户输入的响应。
问题为什么在地狱里a PlaceResult is NOT made available for a Place the user has selected
。 (根据谷歌文档)我做错了什么让谷歌阻止我参加这个活动?
注1 请不要在StackOverflow上就这个主题向我提出任何问题,因为我从早上(超过6个小时)一个接一个地阅读所有这些问题,并且没有任何帮助。
笔记2 javascript的示例来自google maps API文档。
注3 如下面的评论所示,在加载Google地图库时设置语言和区域如下:
<script src="https://maps.googleapis.com/maps/api/js?key=mykey&&language=ar®ion=EG&libraries=places&callback=initMap" async defer></script>
没解决我的问题。
这个问题已在评论中得到解答,我将对此进行总结。 上面的所有内容(在问题中)都是正确的,没有任何错误我只需从谷歌开发者控制台启用Google Places API
这是关于SO的类似问题:Google Map Autocomplete API not adding address options
顺便说一下:正如我在想的那样,当您在搜索框中输入时,place_changed
事件不需要触发。
以上是关于谷歌地图api place_changed事件不是射击的主要内容,如果未能解决你的问题,请参考以下文章
如果用户在Google地图自动填充中选择地址,则忽略模糊事件
在谷歌地图javascript api中 - 如何移动地图而不是标记