国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

CSS之寬高比例布局的方法示例

2024-07-11 08:37:29
字體:
來源:轉載
供稿:網(wǎng)友

在某些特定的場景中,如視頻播放、可視化圖表占位等一些高寬需要固定的比例。如果占位區(qū)間是由固定值確定,那么我們皆大歡喜,但在目前的的應用發(fā)展中寬高自適應的方式才能滿足我們的需求,那么我們該如何這種自適應的 寬高比布局 呢?

什么是寬高比?

寬高比也稱縱橫比,元素的縱橫比描述了其寬度和高度之間的比例關系。兩種常見的視頻寬高比為4:3和16:9。要保持div的寬高比,通過為 padding-top / padding-bottom 添加一個百分比值。不同的寬高比具有不同的百分比值?;虿捎靡暣皢挝?vw / vh 設置相應高寬。其中一些如下所示:

aspect ratiopadding-bottom/top valuevw/vh(width|height)
16:956.25%100vw | 56.25vw
4:375%100vw | 75vw
3:266.66%100vw | 66.66vw
8:562.5%100vw | 62.5vw
2:150%100vw | 50vw

利用padding-top/bottom適配

在CSS中 margin 與 padding 的百分比值是根據(jù)容器的width來計算,利用這一性質我們可以通過設置 padding-top/bottom 的百分比值實現(xiàn)。 采用這種方法,需要把容器的height設置為0,最終容器實際高度由padding撐出。在此基礎上又可分為 偽元素 與 內容絕對定位 兩種方案。這也是目前最佳的處理方式。具體實現(xiàn)如下:

Note: 示例均采用2:1的關系

1、偽元素

適用場景:IE8+ 、現(xiàn)代瀏覽器

優(yōu)點: DOM節(jié)點少、可響應式、需精確到像素


<div class="aspect-ration"></div>


.aspect-ration { background-color: #f00; }
.aspect-ration::before {
content: "";
float: left;
padding-bottom: 50%;
}
.aspect-ration::after {
clear: both;
content: "";
display: table;
}

2、內容絕對定位

適用場景:IE8+ 、現(xiàn)代瀏覽器 優(yōu)點: 可響應式、精確到像素


<div class="aspect-ration">
<div class="content"></div>
</div>


.aspect-ratio {
height: 0;
overflow: hidden;
padding-top: 50%;
background: #f00;
position: relative;
}
.content {
position: absolute; top: 0; left: 0; right: 0; bottom: 0;
/* 或者 */
/* position: absolute; top: 0; left: 0; width: 100%; height: 100%; */
}

視窗單位 vw/vh

利用視窗單位是一種相對于屏幕大小的計算方式,同理我們也也可用用 rem 來達到相同的效果。具體實現(xiàn)與視窗單位一樣。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 东港市| 永吉县| 盘锦市| 巴马| 桦川县| 象山县| 翁源县| 邛崃市| 信宜市| 东乡| 武冈市| 鸡泽县| 来安县| 山丹县| 拜泉县| 那坡县| 和平县| 轮台县| 图们市| 那曲县| 阿图什市| 乌拉特前旗| 囊谦县| 南华县| 眉山市| 宿迁市| 长子县| 竹北市| 石狮市| 新巴尔虎左旗| 宿松县| 华容县| 乌拉特前旗| 香格里拉县| 镇平县| 博湖县| 株洲县| 石城县| 霍邱县| 常熟市| 长治县|