加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

angularjs – ng-map:单击它时如何获取Marker对象?

发布时间:2020-12-17 07:12:53 所属栏目:安全 来源:网络整理
导读:我正在使用非常酷的 ng-map库用于角度,我想知道如何访问由ng-map marker指令引用的基础标记对象 所以,我有这个标记: div id="map-search" data-tap-disabled="true" map zoom="15" disable-default-u-i="true" marker ng-repeat=" pos in positions" positi
我正在使用非常酷的 ng-map库用于角度,我想知道如何访问由ng-map marker指令引用的基础标记对象

所以,我有这个标记:

<div id="map-search" data-tap-disabled="true">
  <map zoom="15" disable-default-u-i="true">
    <marker ng-repeat=" pos in positions" position="{{pos.latitude}},{{pos.longitude}}" id="{{pos.index}}" on-click="pinClicked()">
    </marker>
  </map>
</div>

在这种情况下,我没有找到在点击事件期间访问Google Maps Marker对象的直接方式;从控制器:

app.controller('MapSearchController',function($scope) {

      $scope.$on('mapInitialized',function(event,map) {
        $scope.map = map;
        //Assume existence of an Array of markers
        $scope.positions = generatePinPositionsArray();
      });

      $scope.pinClicked = function(event,marker) {
        console.log('clicked pin!');
        //HOW CAN I GET THE MARKER OBJECT (The one that was clicked) HERE?
        console.log('the marker ->',marker); //prints undefined
      };
  });

提前致谢,

解决方法

你需要创建一个标记数组!那是(在我看来)唯一的方式.见 here

更新:像这个plunkr这样的东西适合你吗?

想法是在事件上传递标记on-click =“pinClicked(this)”.然后你可以在控制器上捕获它:$scope.pinClicked = function(events,marker){…}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读