头闻号

广州格林沃尔化妆品有限公司

护肤膏霜|护肤乳液|防晒油|皮肤用化学品|沐浴液|洗面奶

首页 > 新闻中心 > 科技常识:web响应式布局中iframe自适应的方法
科技常识:web响应式布局中iframe自适应的方法
发布时间:2024-11-27 05:16:41        浏览次数:4        返回列表

今天小编跟大家讲解下有关web响应式布局中iframe自适应的方法 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关web响应式布局中iframe自适应的方法 的相关资料,希望小伙伴们看了有所帮助。

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

这样溢出的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 class="wrap"> <div class="iframe-container"> <iframe height=498 width=510 src="https://www.aidi.net.cn//web/<a href="http://player.youku.com/embed/XOTE0MjkyODgw">http://player.youku.com/embed/XOTE0MjkyODgw</a>"frameborder=0 allowfullscreen></iframe> </div> </div>

结果显示的状态:

当视口宽度大于400px时:

当视口宽度小于400px时:

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

来源:爱蒂网