手机
当前位置:查字典教程网 >网页设计 >XHTML >web响应式布局中iframe自适应的方法
web响应式布局中iframe自适应的方法
摘要:问题在响应式布局中,我们应该小心对待iframe元素,iframe元素的width和height属性设置了其宽度和高度,但是当包含块的宽度或...

问题

在响应式布局中,我们应该小心对待iframe元素,iframe元素的width和height属性设置了其宽度和高度,但是当包含块的宽度或高度小于iframe的宽度或高度时,会出现iframe元素溢出的现象:

web响应式布局中iframe自适应的方法1

这样溢出的iframe会破坏页面的布局。我们可以采用一种方法让iframe元素也具有响应性,拭目以待。

解决方法

iframe元素本身并无法伸缩,除非通过js显示的设置其宽度。但是我们可通过一个iframe-container元素来包裹iframe,同时让iframe-container元素的宽度充满包含块的宽度,并且根据iframe的长宽比,设置iframe-container元素的padding-bottom百分比。

其实,这种方式的精髓就在于设置iframe-container元素的padding-bottom属性,设置该属性的目的在于变相的设置元素的高度。因为给padding-bottom设置百分比,是相对于父元素的width而言的,如果对height属性设置百分比,则相对于父元素的height,而父元素的height值我们通常使用默认的auto,因此会出现子元素height也为0.因此,我们只能给padding-bottom设置属性。这样,只需让iframe元素充满iframe-container即可。

.wrap{

width: 400px;

margin: auto;

border: 5px solid greenyellow;

}

.iframe-container{

height: 0;

padding-bottom: 97.6%;

position: relative;

}

.iframe-container iframe{

position: absolute;

left: 0;

top: 0;

width: 100%;

height: 100%;

}

@media screen and (max-width: 400px) {

.wrap{

width: 300px;

}

}

<div>

<div>

<iframe height=498 width=510 src="<a href="http://player.youku.com/embed/XOTE0MjkyODgw">http://player.youku.com/embed/XOTE0MjkyODgw</a>" frameborder=0 allowfullscreen></iframe>

</div>

</div>

结果显示的状态:

当视口宽度大于400px时:

web响应式布局中iframe自适应的方法2

当视口宽度小于400px时:

web响应式布局中iframe自适应的方法3

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

【web响应式布局中iframe自适应的方法】相关文章:

html 表格比较宽溢出的解决方法

iframe如何刷新的三种实现方案

HTML利用超链接打开链接文件的方法介绍

如何让空格 在 IE 和 FF 里宽度一致的方法?

input checkbox 扩大点击范围的实现方法

html 文本框(text)不可用只读的多种实现方法

向HTML中插入视频并兼容所有浏览器的方法

举例讲解HTML中iframe和frame的区别

input type是什么意思及常用限制input的方法

<td></td>标签的border 样式在浏览器中显示不出来的解决方法

精品推荐
分类导航