javascript - AngularJs、ngRepeat 不起作用

标签 javascript html angularjs

我正在使用 AngularJs。我正在显示带有标记的谷歌地图。单击标记后,我将显示单击的标记详细信息。

这是我的Controller.js

  function createMarker(latitude,longitude,name,address,locationId,sid){
      var marker = new google.maps.Marker({
        map: $scope.map,
        position: new google.maps.LatLng(latitude,longitude),
        title: name
        });
       $scope.leadsForMap=[];
       $scope.location={};
       google.maps.event.addListener(marker, 'click', function() {
       $scope.location = {
                name: name,
                sid: sid,
                address: address,
                locationId:locationId
                };
       $scope.leadsForMap.push($scope.location);
       $scope.markers.push(marker);
   }

在 html 中,我尝试循环 $scope.leadsForMap 数组并在单击后显示特定详细信息

html

    <div  data-ng-repeat="location in leadsForMap track by $index" data-ng-
    if="leadsForMap.length>0">
    {{$index+1}} {{location.name}} - {{location.sid}},{{location.address}}
    </div>   

但是即使 $scope.leadsForMap 有值,这个 div 也根本不显示。谁能告诉我哪里错了?

最佳答案

您需要使用

$scope.$apply()

当事件超出 Angular 范围时,必须使用 $scope.$apply,并且 Angular 不会运行摘要循环,因为它超出了范围。

您需要运行摘要周期,该周期将由 $scope.$apply() 手动运行

google.maps.event.addListener(marker, 'click', function() {
       $scope.location = {
             name: name,
             sid: sid,
             address: address,
             locationId:locationId
       };
       $scope.leadsForMap.push($scope.location);
       $scope.markers.push(marker);
       $scope.$apply();
}

检查When to use $scope.$apply()

关于javascript - AngularJs、ngRepeat 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50019314/

相关文章:

jquery 向下滑动功能无法在导航栏中实现

javascript - 完全等待 FileReader 切片 blob

javascript - 如何使用 angularjs 提交后获取选中的复选框值?

AngularJS重定向未发生在拦截器中

javascript - 检查 2 个 JavaScript 字符串是否指向同一个对象

javascript - 将查询字符串添加到 URL 重定向

javascript - 使用 Promise 时返回 Parse Cloud Code 中更深层次的关系

javascript - Facebook 图表所有共同的 friend

jquery - 导航之外没有可点击的内容(hrefs 或点击功能)

javascript - AngularJS 应用程序未启动