0

在 Google Maps API v3 中,他们声明我们需要这样做才能在单击标记时打开信息窗口:

google.maps.event.addListener(marker, 'click', function() {
    infowindow.open(map,marker);
});

现在我正在尝试使用 js 库在 dart 中复制它。到目前为止,我有这样的事情:

final google_maps = context['google']['maps'];

var myLatlng = [43.5, -6.5];
var center = new JsObject(google_maps['LatLng'], myLatlng);

var mapTypeId = google_maps['MapTypeId']['ROADMAP'];

var mapOptions = new JsObject.jsify({
  "center": center,
  "zoom": 8,
  "mapTypeId": mapTypeId
});

var map = new JsObject(google_maps['Map'], [querySelector('#map-canvas'), mapOptions]);

var marker = new JsObject(google_maps['Marker'], [new JsObject.jsify({
  'position': center,
  'map': map,
  'title': 'Hello World!'
})]);

var tooltip = '<div id="content">Info window coontent</div>';

var infowindow = new JsObject(google_maps['InfoWindow'], [new JsObject.jsify({
"content": tooltip
})]);


google_maps['event'].callMethod('addListener', [marker, 'click', () {
  infowindow.callMethod('open',[map,marker]);
}]);

问题是我通过 google_maps['event'] 设置了 'addListener' 方法,但是当我单击标记时,我得到一个 NoSuchMethodError:

Closure call with mismatched arguments: function 'call'

NoSuchMethodError: incorrect number of arguments passed to method named 'call'
Receiver: Closure: () => dynamic
Tried calling: call(Instance of 'JsObject')
Found: call()

我知道有一个google_maps dart 包,但我希望使用 dart 的 js 库与 javascript api 进行交互。

提前致谢。

4

1 回答 1

6

您的闭包参数为零。

() {
   infowindow.callMethod('open',[map,marker]);
}

你只需要给它一个参数,如错误消息中所述:

(event) {
   infowindow.callMethod('open',[map,marker]);
}
于 2014-08-29T16:54:38.650 回答