响应式iframe(谷歌地图)和奇怪的大小调整

Cor*_*nne 47 css iframe google-maps responsive-design

我正在尝试在我的设计中添加Google地图,这应该是响应式的.我使用了与图像相同的代码......但由于某种原因,地图的iframe会根据我没有选择的尺寸进行调整.

HTML

<iframe src="http://maps.google.com/maps/ms?vpsrc=6&amp;ctz=-480&amp;ie=UTF8&amp;msa=0&amp;msid=210840796990572645528.00049770919ccd6759de3&amp;t=m&amp;ll=30.751278,68.203125&amp;spn=84.446143,175.429688&amp;z=2&amp;output=embed" frameborder="0" marginwidth="0" marginheight="0" scrolling="no" width="635" height="300">    </iframe>?
Run Code Online (Sandbox Code Playgroud)

和CSS

iframe {
max-width: 100%;
height: auto;
width: auto; /*IE8 bug fix*/
vertical-align: middle;}
Run Code Online (Sandbox Code Playgroud)

或者你可以在这里查看它并在这里摆弄它:http: //jsfiddle.net/corinne/pKUzU/ (如果你切掉CSS,你会看到我的意思).

我的问题是如何使这个iframe /地图响应而不会失去它想要的高度?

cpg*_*cpg 96

这个解决方案来自Dave Rupert/Chris Coyier(我想).它需要一个包装div,但效果很好.

HTML

    <div class="iframe-rwd">
        <iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="https://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&amp;geocode=&amp;q=Seattle,+WA&amp;aq=0&amp;oq=seattle&amp;sll=37.822293,-85.76824&amp;sspn=6.628688,16.907959&amp;t=h&amp;ie=UTF8&amp;hq=&amp;hnear=Seattle,+King,+Washington&amp;z=11&amp;ll=47.60621,-122.332071&amp;output=embed"></iframe><br /><small><a href="https://maps.google.com/maps?f=q&amp;source=embed&amp;hl=en&amp;geocode=&amp;q=Seattle,+WA&amp;aq=0&amp;oq=seattle&amp;sll=37.822293,-85.76824&amp;sspn=6.628688,16.907959&amp;t=h&amp;ie=UTF8&amp;hq=&amp;hnear=Seattle,+King,+Washington&amp;z=11&amp;ll=47.60621,-122.332071" style="color:#0000FF;text-align:left">View Larger Map</a></small>
    </div>
Run Code Online (Sandbox Code Playgroud)

CSS

.iframe-rwd  {
position: relative;
padding-bottom: 65.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
.iframe-rwd iframe {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
Run Code Online (Sandbox Code Playgroud)

  • 非常感谢,它有效,奇迹!:)希望我能给你一些积分,但遗憾的是我还是新手! (2认同)