我想在Google Maps API(v3)InfoWindow中添加一个带有输入字段和提交按钮的表单.
提交时,我想调用一个函数,使用输入到输入字段中的地址启动指向服务.
这是我的代码(我目前只测试方向事件是否被触发.我已经编写完整的getDirections()事件并且可以确认它有效并在正确触发时返回指示):
我尝试使用MooTools添加一个事件监听器,如下所示:
var infoWindowContent = "<b>Get Directions From...</b><br />"
+ "<form id='map-form'>"
+ "Address/Postcode: <input id='map-from-address' type='text' />"
+ "<input type='submit' id='map-go' value='Go' />"
+ "</form>";
var infoWindow = new google.maps.InfoWindow({
content: infoWindowContent
});
google.maps.event.addListener(marker, 'click', function() {
infoWindow.open(map, marker);
dbug.log($("map-form"));
$("map-form").addEvent("submit", getDirections);
});
function getDirections(event)
{
dbug.log("getDirections");
event.stop();
}
Run Code Online (Sandbox Code Playgroud)
当我在我的网站的其他地方使用MooTools时,我将所有代码放入其中 window.addEvent('load', function(){...});
请注意dbug.log($("map-form"));正确输出表单元素的控制台跟踪,但事件未触发.
我在DOM中将相同的事件添加到另一个表单(具有不同的ID)并且它工作正常.
那么,如果MooTools可以找到该元素并据说添加事件监听器,那么阻止事件触发的是什么?这是范围问题吗?
javascript mootools infowindow google-maps-api-3 mootools-events