谷歌地图没有填写模态弹出窗口

时间:2013-05-13 22:48:18

标签: javascript html css

当用户点击地图on this page here时,我正在使用模态弹出窗口,这会弹出一张包含路线的更大地图。

地图并没有填满整个空间,但我无法弄清楚原因。当我右键单击它以检查chrome检查器时,它会使地图​​填充模态。

请原谅所有代码,但我认为最好将其全部包括在内:

       <div class="map clearfix">
            <div class="bg left-contact">
            <% if len(""&rsAdvert("ContactPostcode"))>0 then %>
                      <a href="#myModal" role="button" data-toggle="modal">
<div class="small-map" style="width:100%;height:130px;background:url(http://maps.google.com/maps/api/staticmap?center=<%=server.URLEncode(""&rsAdvert("ContactPostcode"))%>&zoom=14&size=250x250&maptype=roadmap&markers=color:ORANGE|label:A|<%=server.URLEncode(""&rsAdvert("ContactPostcode"))%>&sensor=false) center no-repeat;"></div></a>
                      <div class="expand"></div>
    <!-- Modal -->
    <div id="myModal" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
        <h3 id="myModalLabel">Modal header</h3>
      </div>
      <div class="modal-body">
        <p><div id='map-canvas'></div></p>
      </div>
      <div class="modal-footer">
        <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
        <button class="btn btn-primary">Save changes</button>
      </div>
    </div>
        <script src="http://code.jquery.com/jquery.js"></script>
        <script src="/js/bootstrap/js/bootstrap.min.js"></script>
               <% end if %> 
            </div>
        </div>

     <script src="http://maps.googleapis.com/maps/api/js?q=London&key=AIzaSyBaPEDyFbbnWjtvT8W3UBOM34Y7g6vK69A&sensor=false"></script>
    <script>
        var map;
        function initialize() {
          var mapOptions = {
            zoom: 15,
            center: new google.maps.LatLng(-34.397, 150.644),
            mapTypeId: google.maps.MapTypeId.ROADMAP
          };
          var geolocate = function(address, callback) {
                $.ajax({
                        url: "http://maps.googleapis.com/maps/api/geocode/json",
                        data: {
                            "sensor": true,
                            "address": address
                        },
                        dataType: "json",
                        success: function(d) {
                            if (d.status == "ZERO_RESULTS") callback(false);
                            if (d.results && d.results[0] && d.results[0].geometry) {
                                callback({
                                    "ne": d.results[0].geometry.bounds.northeast,
                                    "sw": d.results[0].geometry.bounds.southwest,
                                    "center": d.results[0].geometry.location
                                });
                            }
                            else callback(false);
                        }
                    });
          };
          map = new google.maps.Map(document.getElementById('map-canvas'),
              mapOptions);
          geolocate("<%=server.URLEncode(""&rs("ca_postcode"))%>", function(c) {
                map.setCenter(new google.maps.LatLng(c.center.lat, c.center.lng));
         });
        }
        google.maps.event.addDomListener(window, 'load', initialize);
    </script>

感谢。

5 个答案:

答案 0 :(得分:4)

为了完整性:如果您使用Bootstrap modal window,则需要使用shown.bs.modal事件代替shown事件。

这里是代码:

  $("#modalWindowId").on("shown.bs.modal", function(e) {
    google.maps.event.trigger(map, "resize");
    map.setCenter(markerLatLng); // Set here center map coordinates
  });

在这里了解更多信息: http://coderpills.wordpress.com/2014/06/02/showing-google-map-inside-a-bootstrap-modal-window/

答案 1 :(得分:3)

在模式启动后,您可以在地图上触发resize事件,这会使其调整大小以适应包含div的尺寸。来自documentation

  

当div更改时,开发人员应在地图上触发此事件   大小

// Add this at the bottom of the script which defines your map
// It will trigger the resize event on the map after the modal has launched
$('#myModal').on('shown', function () {
  google.maps.event.trigger(map, 'resize');
})

我认为当您启动开发工具时,window.onResize事件会导致在地图上触发resize事件。您可以通过在单击模式之前从浏览器窗口中分离开发工具来证明这一点。

答案 2 :(得分:0)

尝试使用此

填充:0;

的CSS:

.modal-body {
max-height: 400px;
overflow-y: auto;
padding: 0;
position: relative;
     }

答案 3 :(得分:0)

谢谢你的回答。只是为了帮助其他可能有这个问题的人,除了由于将地图放在模态中而必须调整大小之外,我还必须重置中心。

以下代码需要添加到initialize函数中。

    $('#show_map').on('shown', function () {
        google.maps.event.trigger(map, "resize");
        map.setCenter(myLatlng);
    });

答案 4 :(得分:0)

$('#Map_Modal_ID').on('shown.bs.modal', function () {
    initialize();
});
相关问题