我想知道为什么我收到以下错误:
类型错误:e.row.beachID 未定义
我的 click 事件处理程序按预期工作,但我的 mouseover 和 mouseout 事件处理程序虽然类似于 click 处理程序输出上面提到的 TypeError 消息。如果我能够使用“单击处理程序”从 gft 检索图层数据,那么为什么我不能对“鼠标悬停”和“鼠标输出”处理程序执行相同的操作 - 我正在尝试从同一个表中检索数据。
/* start map initialization */
function initialize() {
latlng = new google.maps.LatLng(49.894634, -97.119141);
var myOptions = {
center: latlng,
zoom: 7,
mapTypeId: google.maps.MapTypeId.ROADMAP,
zoomControlOptions: {
style: google.maps.ZoomControlStyle.SMALL
},
mapTypeControl: true,
mapTypeControlOptions: {
mapTypeIds: [
google.maps.MapTypeId.ROADMAP,
google.maps.MapTypeId.SATELLITE,
google.maps.MapTypeId.HYBRID,
google.maps.MapTypeId.TERRAIN
],
style: google.maps.MapTypeControlStyle.DROPDOWN_MENU
},
overviewMapControl: true,
overviewMapControlOptions: {
opened: true
}
};
map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
layer = new google.maps.FusionTablesLayer({
query: {
select: 'POINT',
from: tableID
},
suppressInfoWindows: true
});
layer.setMap(map);
infoWindow = new google.maps.InfoWindow();
// begin tooltip section
layer.enableMapTips({
select: "'beachID', 'beach'",
from: tableID,
geometryColumn: 'POINT',
suppressMapTips: true,
delay: 100,
tolerance: 8
});
google.maps.event.addListener(layer, 'mouseover', function (e) {
$('#info').html(
'<h3>' + e.row['beachID'].value + '</h3>',
'<h3>' + e.row['beach'].value + '</h3>');
});
google.maps.event.addListener(layer, 'mouseout', function (e) {
$('#info').html('<h2>Mouseout</h2>') ;
});
// end tooltip section
google.maps.event.addListener(layer, 'click', function (e) {
// close infoWindow if open
if (infoWindow) {
infoWindow.close();
}
beachID = e.row['beachID'].value;
beachName = e.row['beach'].value;
point = e.row['POINT'].value;
region = e.row['region'].value;
sampleDate = e.row['Date'].value;
ecoli_count = e.row['avg_ecoli_count'].value;
water_quality_guideline = e.row['water_quality_guideline'].value;
});
}
我错过了什么明显的东西吗?任何想法总是受到赞赏。
提前致谢。迈克尔