Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/backbone.js/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Backbone.js视图中的Google地图侦听器_Backbone.js_Google Maps Api 3_Google Maps Markers - Fatal编程技术网

Backbone.js视图中的Google地图侦听器

Backbone.js视图中的Google地图侦听器,backbone.js,google-maps-api-3,google-maps-markers,Backbone.js,Google Maps Api 3,Google Maps Markers,我想在Backbone.ja应用程序中,在我的谷歌地图上的标记上切换打开和关闭Infowindow div 在我看来,我有一个初始化函数,它包含google.maps.event.addListener function initialize(viewOptions, app) { this.app = app; this.address = ''; this.terms = [ 'Food', 'Bar' ]; // this.listenTo(

我想在Backbone.ja应用程序中,在我的谷歌地图上的标记上切换打开和关闭Infowindow div

在我看来,我有一个初始化函数,它包含google.maps.event.addListener

function initialize(viewOptions, app) {
  this.app = app;
  this.address = '';
  this.terms = [
      'Food',
      'Bar'
    ];
  // this.listenTo(this.collection, 'reset', this.render);
  this.listenTo(this.collection, 'add', this.addmarker);
  this.render();
  google.maps.event.addListener(map, 'click', function() {
    console.log('Clicked')
    // infoclicker.call(); 
  });
};
这个addListener似乎不起作用。当我点击一个标记,甚至是地图上的任何地方,它都不会触发console.log。我做错了什么

仅供参考:渲染函数调用了一个_setMap函数,用于设置贴图

function _setMap(zoom, lat, long) {
  var mapOptions = {
      zoom: zoom ? zoom : 15,
      center: new google.maps.LatLng(lat ? lat : 45.5200,long ? long : -122.6819)
    };

  this.map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
};
这应该做到:

google.maps.event.addListener(this.map, 'click', function() {
  console.log('Clicked');
});

检查用于映射和标记的变量的范围。它们应该在您试图在其上添加操作侦听器的函数范围内。

addListener
调用中
map
是什么?我相信“map”是在_setMap函数中创建的google map对象的实例。当您调用
\u setMap
时,是否有一个
\map canvas
?是否有一个#map canvas调用_setmap时的映射模板。是在模板中还是在页面本身上?您是否检查了
document.getElementById('map-canvas')
是否返回了您期望的内容?看起来是这样的。在addListener中,您引用的是不存在的
map
变量。您正在将其作为对象属性存储在
this.map
中。如果
\u setMap
是与
initialize
相同的对象的方法,不幸的是,这仍然不能实现。