web響應(yīng)式布局中iframe自適應(yīng)的方法
問題
在響應(yīng)式布局中,我們應(yīng)該小心對待iframe元素,iframe元素的width和height屬性設(shè)置了其寬度和高度,但是當(dāng)包含塊的寬度或高度小于iframe的寬度或高度時,會出現(xiàn)iframe元素溢出的現(xiàn)象:
這樣溢出的iframe會破壞頁面的布局。我們可以采用一種方法讓iframe元素也具有響應(yīng)性,拭目以待。
解決方法
iframe元素本身并無法伸縮,除非通過js顯示的設(shè)置其寬度。但是我們可通過一個iframe-container元素來包裹iframe,同時讓iframe-container元素的寬度充滿包含塊的寬度,并且根據(jù)iframe的長寬比,設(shè)置iframe-container元素的padding-bottom百分比。
其實,這種方式的精髓就在于設(shè)置iframe-container元素的padding-bottom屬性,設(shè)置該屬性的目的在于變相的設(shè)置元素的高度。因為給padding-bottom設(shè)置百分比,是相對于父元素的width而言的,如果對height屬性設(shè)置百分比,則相對于父元素的height,而父元素的height值我們通常使用默認(rèn)的auto,因此會出現(xiàn)子元素height也為0.因此,我們只能給padding-bottom設(shè)置屬性。這樣,只需讓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="<a frameborder=0 allowfullscreen></iframe>
</div>
</div>
結(jié)果顯示的狀態(tài):
當(dāng)視口寬度大于400px時:
當(dāng)視口寬度小于400px時:
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
上一篇:HTML頁面自動清理js、css文件的緩存(自動添加版本號)
欄 目:CSS/HTML
本文標(biāo)題:web響應(yīng)式布局中iframe自適應(yīng)的方法
本文地址:http://mengdiqiu.com.cn/a1/CSS_HTML/9550.html
您可能感興趣的文章


閱讀排行
本欄相關(guān)
- 04-02表格樣式css樣式,css樣式表單
- 04-02好看的字體樣式css,好看的字體樣式圖
- 04-02分頁樣式css,分頁樣式j(luò)q
- 04-02分頁樣式css,分頁樣式欄里用來定義首
- 04-02css樣式的引入,css樣式怎么引入
- 04-02css滾動條樣式,css滾動條的樣式
- 04-02css樣式引入方式有幾種,網(wǎng)頁引入css樣
- 04-02html中加入css樣式的簡單介紹
- 04-02vue中的css樣式布局,vue添加css樣式
- 04-02內(nèi)嵌樣式css,內(nèi)嵌樣式表,內(nèi)部樣式表
隨機閱讀
- 01-10vue實現(xiàn)分頁加載效果
- 01-10C++ 類訪問控制的條件總結(jié)
- 01-10bat批處理徹底隱藏文件的方法(使用
- 01-10C語言打印楊輝三角示例匯總
- 01-11常用的HTML富文本編譯器UEditor、CKEdi
- 08-05dedecms織夢模板編輯文檔的同時自動更
- 08-05DEDECMS點擊主欄目默認(rèn)顯示第一個子欄
- 01-10C++實現(xiàn)將數(shù)組中的值反轉(zhuǎn)
- 08-05織夢dedecms首頁調(diào)用縮略圖為背景
- 08-05dedecms織夢模板全站調(diào)用收藏數(shù)的方法