我正在使用谷歌地图api自动完成来搜索机构的城市和国家。 为此,我有一个输入字段和搜索位置的地图预览。 这是 jsfiddle,但它在 momemnt (https://jsfiddle.net/rxp7hdLk/2/( 不起作用
问题是:
当我搜索某个位置时,它会获取其城市和国家/地区,但不会更新该位置的地图预览。它在默认预览上锁定。
我目前有以下位:
autocomplete.addListener('place_changed', function(){
infowindow.close();
marker.setVisible(false);
var place = autocomplete.getPlace();
if (place.geometry.viewport) {
map.fitBounds(place.geometry.viewport);
} else {
map.setCenter(place.geometry.location);
map.setZoom(17);
}
marker.setIcon( /** @type {google.maps.Icon} */ ({
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);
您正在添加两个函数/侦听器来执行相同的操作。
请删除应用程序中与自动完成上的 ng-change 相关的相关代码(cityCode,两个函数(:
ng-change="cityCode()"
同样在控制器中:
$scope.cityCode = cityCode;
function cityCode() {
释放 cityCode(( 内部和控制器内部的代码。根本不需要城市代码。
这是一个工作的小提琴。
在开始时使变量全局:
var map;
var marker;
$scope.city = '';
$scope.country = '';