0

我将bpopup 插件用于 ajax 弹出窗口。我需要使用谷歌地图显示弹出窗口。显示弹出窗口没有问题。

js

$(document).on('click', '.aboutBranch', function(e){
  e.preventDefault();
  $.ajax({
    type: 'POST',
    url: '/ajax/show-branch',
    data: {delivery_id: ..., branch_id: ...},
    success: function(html) {
      $('#BranchBox').html(html);
      $('#BranchBox').bPopup();
    }
  });
});

在将 ajax 附加到 #BranchBox 的模板中很简单。谷歌地图周围也有东西。我尝试了同步和异步加载地图。但两者都不起作用。有时地图已加载,但大多没有。超时没有帮助。您是否有将谷歌地图附加到 ajax 加载的内容(即使使用 bpopup)的经验?谢谢你的建议。

模板

<div id="map_canvas" style="width: 100%; height: 400px;"></div>

<script type="text/javascript">
  function initialize() {
    var mapOptions = {
      center: { lat: parseFloat(latFromPhp), lng: parseFloat(lngFromPhp)},
      zoom: 15
    };

    var map = new google.maps.Map(document.getElementById('map_canvas'), mapOptions);

    var marker = new google.maps.Marker({
      position: new google.maps.LatLng(parseFloat(latFromPhp), parseFloat(lngFromPhp)),
      title: titleFromPhp
    });

    marker.setMap(map);
  }

  //async load
  function loadScript() {
    var script = document.createElement('script');
    script.type = 'text/javascript';
    script.src = 'https://maps.googleapis.com/maps/api/js?v=3.exp&' + 'callback=initialize';
    document.body.appendChild(script);
  }

  window.onload = loadScript;


  //sync load (googleapis is included in main layout)
  google.maps.event.addDomListener(window, 'load', initialize);
</script>
4

1 回答 1

0
  1. 立即运行函数,无需等待事件,因为弹出窗口打开时窗口已经加载

  2. 不要使用异步加载器,因为它会在您每次打开弹出窗口时加载 API(这可能会导致错误),此外它会增加弹出窗口内地图的加载时间(它首先等待 ajax-响应,然后用于 API)

  3. 当您创建地图实例时,地图 API 会计算地图容器的大小。当弹出窗口此时还没有最终大小时,您会错过一些图块。加载弹出窗口时触发窗口的调整大小事件以加载图块(的第二个参数bPopup())。在这种情况下,API 会触发地图的调整大小事件(地图的大小将被重新计算并加载丢失的图块)

    $('#BranchBox')
     .bPopup({},function(){google.maps.event.trigger(window,'resize',‌​{});}); 
    
于 2014-11-27T23:32:34.317 回答