3

这应该准确显示我正在努力解决的问题:http: //jsfiddle.net/PaulHighten/c5knqdgd/

<div class="panel-group" id="accordion" role="tablist" aria-multiselectable="true">
  <div class="panel panel-default">
    <div class="panel-heading" role="tab" id="headingParis">
      <h4 class="panel-title">
        <a class="collapsed" data-toggle="collapse" data-parent="#accordion" href="#collapseParis" aria-expanded="true" aria-controls="collapseParis">
          Eiffel Tower, Paris
        </a>
      </h4>
    </div>
    <div id="collapseParis" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingParis">
      <div class="panel-body">
        <div class="googlemap">
          <iframe width="600" height="450" frameborder="0" style="border:0"
src="https://www.google.com/maps/embed/v1/place?q=Eiffel%20Tower%2C%20Avenue%20Anatole%20France%2C%20Paris%2C%20France&key=AIzaSyAFUKSu28KvFk67YcSlUWeUJ2TpcifSVmQ"></iframe>
        </div>
      </div>
    </div>
  </div>
  <div class="panel panel-default">
    <div class="panel-heading" role="tab" id="headingLondon">
      <h4 class="panel-title">
        <a class="collapsed" data-toggle="collapse" data-parent="#accordion" href="#collapseLondon" aria-expanded="false" aria-controls="collapseLondon">
          Trafalgar Square, London
        </a>
      </h4>
    </div>
    <div id="collapseLondon" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingLondon">
      <div class="panel-body">
        <div class="googlemap">
          <iframe width="600" height="450" frameborder="0" style="border:0"
src="https://www.google.com/maps/embed/v1/place?q=Trafalgar%20Square%2C%20London%2C%20United%20Kingdom&key=AIzaSyAFUKSu28KvFk67YcSlUWeUJ2TpcifSVmQ"></iframe>
       </div>
    </div>
  </div>
</div>

巴黎面板正确显示地图,因为它有一个“in”类。

London 面板没有该类,这意味着 bootstrap 应用 display: none; 到那个面板。我假设这会阻止 iframe 正确运行它的 http 请求。

可以使用 Google Maps Embed API 来实现这一点吗?我已经看到很多与 API v3 和 initialize() 调用有关的问题,但很难找到与使嵌入 iframe 代码工作相关的任何问题。

提前致谢。

==================

编辑:我使用的代码解决了这个问题(对克里斯蒂娜的回答稍作修改,只更新相关的 iframe 一次):

$('[data-toggle="collapse"]').click('show.bs.collapse', function() {
  var mapFrame = $($(this).attr('href') + ' .googlemap iframe');
  if (!$(mapFrame).hasClass('map-refreshed')) {
    mapFrame.attr('src', mapFrame.attr('src')+'');
    mapFrame.addClass('map-refreshed');
  }
});
4

1 回答 1

3

在 shown.bs.collapse 或 show.bs.collapse 函数上刷新 iframe 源

$('[data-toggle="collapse"]').click('shown.bs.collapse', function() {  
     var googleIframe = $('.googlemap iframe');
      googleIframe.attr('src',googleIframe.attr('src')+'');
});

演示:http: //jsfiddle.net/ekba9y8w/

假设 .googlemap 是 iframe 的父级。

Paul Highten 的更新,所以它不会继续刷新:

$('[data-toggle="collapse"]').click('show.bs.collapse', function() {
  var mapFrame = $($(this).attr('href') + ' .googlemap iframe');
  if (!$(mapFrame).hasClass('map-refreshed')) {
    mapFrame.attr('src', mapFrame.attr('src')+'');
    mapFrame.addClass('map-refreshed');
  }
});
于 2014-11-02T19:39:37.607 回答