jquery - 将 addDomListener 与 googlemaps 一起使用不起作用

标签 jquery google-maps-api-3

我通过在 php 中查询数据库,然后将数据发送到 addMarker 函数,为 googlemap 构建了标记。

对于每个标记,都有 0 到未知数量的“违规”。我已将每个标记的违规放入一个数组(称为违规),并将其也发送到 addMarker 函数。

我想做的是为每个违规行为提供一个链接。单击该链接后,您会看到该违规行为的详细信息(表格)。

该表最初是显示:无。但是,当您单击该链接时,我希望显示被阻止并且链接消失。

我想使用 jquery 来完成此任务,但我在实现它时遇到了困难。

我一直在尝试使用 addDomListener,但它对我不起作用 - 它会破坏页面,并且没有明确的错误消息。谁能告诉我如何正确使用 addDomListener,或者我应该使用其他东西吗?

function addMarker(point, name, violations, map) {
            var marker=new google.maps.Marker({
              position:point,
              icon:'circle.png'
              });

            marker.setMap(map);


            var markerhtml = "";
            markerhtml += "<div class='table-responsive'><table class='table-condensed'><tr><th colspan='2'>" + name + "</th></tr>";

            markerhtml += "</table>";
            vCount = violations.length/6; //6=number of fields per violation; vCount = number of violations
            if (violations.length > 0) {
                markerhtml += "<p><strong>Violation";
                if (violations.length > 6) {
                    markerhtml += "s"; //make it 'violationS' if there are more than one violation
                }
                markerhtml += "</strong></p>";
                for (var j=0; j<vCount; j++) {
                    vIncidentDate = violations[0+(j*6)];
                    vFineDate = violations[1+(j*6)];
                    vFineAmount = violations[2+(j*6)];
                    vLeadPermit = violations[3+(j*6)];
                    vViolationDescription = violations[4+(j*6)];

                    markerhtml += "<div class='desc' id='desc" + j + "'>" + vViolationDescription + "</div>";
                    var thisDesc = document.getElementById("desc"+j);
                    google.maps.event.addDomListener($("#thisDesc")[0], 'click', 
                                 function(){ 
                                    $(thisDesc).fadeOut();
                                    $('#tblViolations'+j).fadeIn('slow');
                                 });    
                    vResponse = violations[5+(j*6)];

                    markerhtml += "<table id='tblViolation" + j + "' class='table-responsive table-condensed tblViolation'><tr class='nDesc'><td>Incident date:</td><td>" + vIncidentDate + "</td></tr>";
                    markerhtml += "<tr><td>Fine date:</td><td>" + vFineDate  + "</td></tr>";
                    markerhtml += "<tr><td>Fine amount:</td><td>" + vFineAmount;

                    markerhtml += "</td></tr>";
                    markerhtml += "<tr><td>Description:</td><td>" + vViolationDescription + "</td></tr>";
                    markerhtml += "<tr><td>Response:</td><td>" + vResponse + "</td></tr>";


                }
                markerhtml += "</table></div>";

            }



            google.maps.event.addListener(marker, 'click', function() {
                                      currentCenter=map.getCenter();
                                      infowindow.setContent(markerhtml);
                                      infowindow.setPosition(point);
                                      infowindow.open(map);
            }); 


            google.maps.event.addListener(infowindow, 'closeclick', function() {
                                         map.setCenter(new google.maps.LatLng(41.0342375, -77.3066405));
            });

最佳答案

$("#thisDesc")[0] 在信息窗口中查找元素时似乎出现问题。在信息窗口“domready”事件触发之前,它不会存在于 DOM 中并且可以找到。将 JQuery 代码放入在 infowindows 'domready' 事件上运行的函数内。

google.maps.event.addListener(infowindow, 'domready', function() {
  // code here
});

关于jquery - 将 addDomListener 与 googlemaps 一起使用不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21558724/

相关文章:

javascript - 谷歌地图 v3 JavaScript : geojson overlays city and country names

google-maps - 隐藏谷歌地图平面图

javascript - markwithlabel 可以与 google.maps.circle 一起使用吗?

javascript - 如何在 jQuery 中的文档就绪事件上自动调用函数

reactjs - 在 Gatsbyjs (Reactjs) 项目中加载 Google Place API

javascript - 如何根据从不同选项卡中选择的项目添加总成本

javascript - 在原型(prototype)中使用 css 选择器触发点击事件

javascript - Google Maps API 如何让点击监听器识别拖动

javascript - Select2 - 禁用用户输入选择

jquery - 如何删除div中的p标签?