谷歌地图api自动完成显示地图预览的位置

时间:2017-08-16 11:07:27

标签: javascript angularjs google-maps google-maps-api-3 angularjs-scope

我正在使用谷歌地图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);

2 个答案:

答案 0 :(得分:1)

您正在添加两个函数/侦听器来执行相同的操作。

请删除应用程序中与自动填充中的ng-change相关的相关代码(cityCode,两个函数):

ng-change="cityCode()"

同样在您的控制器中:

$scope.cityCode = cityCode;

function cityCode() {

释放cityCode()内的代码,然后在控制器内部释放。根本不需要cityCode。

这里是working fiddle

答案 1 :(得分:0)

在开头使变量成为全局变量:

var map;
var marker;
$scope.city = '';
$scope.country = '';