實(shí)例講解如何使用CSS保持頁(yè)面內(nèi)容寬高比

需求描述:移動(dòng)端實(shí)現(xiàn)橫跨頁(yè)面半圓。(類似問(wèn)題,實(shí)現(xiàn)4x4的正方形網(wǎng)格)
簡(jiǎn)化問(wèn)題,我們可以理解為實(shí)現(xiàn)一個(gè)高度和寬度比為1:2的塊。
需要解決問(wèn)題:
1,高度和寬度按照一定比例。
2,外容器高度和寬度不確定。
3,盡量不使用圖片和腳本替代。
4,兼容移動(dòng)端。
編寫html
- <div class = "semicircle"></div>
思考一,使用height:100%,
- body{
- margin:0;
- width: 100%;
- background: lightblue;
- }
- .semicircle {
- width: 100%;
- height: 100%;
- border-top:5px solid #fff;
- border-radius: 100%;
- }
存在問(wèn)題,height的百分比是根據(jù)父容器計(jì)算的,不是當(dāng)前容器,根本滿足不了我們的需求。效果如下:
父容器body的高度百分比為其子容器所填充的高度關(guān)聯(lián),即便設(shè)置body高度100%,由于子容器即semicircle所填充的實(shí)際高度為邊界的5,無(wú)法將父容器“全部撐開”,因此無(wú)法通過(guò)設(shè)定父容器的高度為百分比指定寬高按照一定比例的容器。
思考二,設(shè)定padding-top或padding-bottom為100%
The percentage is calculated with respect to the width of the generated box's containing block [...] (source: w3.org, emphasis mine)
百分比寬度的計(jì)算與所生成盒子的包含塊寬度有關(guān)。padding-top、padding-bottom的百分比是根據(jù)父容器的width(寬度)計(jì)算的,而不是height(高度)。其他比例實(shí)現(xiàn)對(duì)照表
aspect ratio | padding-bottom value |
---|---|
16:9 | 56.25% |
4:3 | 75% |
3:2 | 66.66% |
8:5 | 62.5% |
- body{
- margin:0;
- width: 100%;
- background: lightblue;
- }
- .semicircle {
- width: 100%;
- height: 0;
- padding-bottom: 100%;
- border-top:5px solid #fff;
- border-radius: 100%;
- }
思考三,使用vw單元
使用vw單元設(shè)定元素高度和寬度,vm的大小是通過(guò)viewport的寬度設(shè)定的,因此可以通過(guò)該方法保持容器按照一定比例顯示。一單位的vw等于百分之一的viewport寬度,即100vw等于100%viewport寬度。
- body{
- margin:0;
- width: 100%;
- background: lightblue;
- }
- .semicircle {
- width: 100vw;
- height:100vw;
- border-top:5px solid #fff;
- border-radius: 100%;
- }
對(duì)照表
aspect ratio | multiply width by |
---|---|
1:1 | 1 |
1:3 | 3 |
4:3 | 0.75 |
16:9 | 0.5625 |
思考四,使用偽元素和inline-block布局
- body {
- width: 100%;
- font-size: 0;
- text-align: center;
- background: lightblue;
- }
- .semicircle {
- border-top:5px solid #fff;
- border-radius: 100%;
- }
- .semicircle:before {
- content:"";
- display: inline-block;
- padding-bottom: 100%;
- }
雖然代碼有點(diǎn)復(fù)雜,但是靈活性強(qiáng),可以實(shí)現(xiàn)更多類似的效果。
當(dāng)需求改成實(shí)現(xiàn)一個(gè)橫跨屏幕80%的寬度的半圓,我們只需要在.semicircle中添加屬性width:80%;,順便也把容器居中實(shí)現(xiàn)了。
該方法的原理很清晰:
參考思考一,無(wú)法通過(guò)高度100%來(lái)擴(kuò)充外容器高度,那么可以通過(guò)偽元素,插入一個(gè)高度和寬度一致的元素,將容器撐開成一比一高度的容器。注意,該方法實(shí)現(xiàn)半圓,實(shí)際需要寬高為一比一的容器,即占用空間為上述方法的兩倍。
設(shè)置:before元素邊界,解析原理:
思考五,使用圖片,兼容低檔次移動(dòng)設(shè)備。
- .semicircler img {
- width: 100%;
- background-repeat: no-repeat;
- background-size: 100% 100%;
- background-image: url(../img/autoresized-picture.jpg);
- }
使用腳本,css更加簡(jiǎn)潔明了,目標(biāo)清晰。
- div.style.height=div.offsetWidth+"px";
對(duì)于實(shí)現(xiàn)2*2正方形網(wǎng)格
- *------main code-------*/
- body {
- width: 100%;
- margin:0;
- text-align: center;
- }
- div{
- display: inline-block;
- width: 50%;
- background: lightblue;
- font-size: 12px;
- position: relative;
- vertical-align: middle;
- }
- div:before {
- content:"";
- display: inline-block;
- padding-bottom: 100%;
- vertical-align: middle;
- }
- /*------other code-------*/
- div:nth-child(2),div:nth-child(3){
- background: pink;
- }
- span {
- display: inline-block;
- vertical-align: middle;
- font-size: 6em;
- color: #fff;
- }
相關(guān)文章
CSS 實(shí)現(xiàn)div寬度根據(jù)內(nèi)容自適應(yīng)
最近做了個(gè)項(xiàng)目,其中有項(xiàng)目需求是需要div根據(jù)內(nèi)容進(jìn)行寬度自適應(yīng)。下面小編給大家分享一段代碼關(guān)于CSS 實(shí)現(xiàn)div寬度根據(jù)內(nèi)容自適應(yīng) 的相關(guān)知識(shí),需要的朋友參考下2016-01-28CSS實(shí)現(xiàn)菜單背景自適應(yīng)寬度的方法
這篇文章主要為大家介紹了CSS實(shí)現(xiàn)菜單背景自適應(yīng)寬度的方法,涉及基于css屬性控制背景圖片自適應(yīng)寬度的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-28CSS基于單張背景圖實(shí)現(xiàn)自適應(yīng)寬度的圓角菜單效果代碼
這篇文章主要為大家介紹了CSS基于單張背景圖實(shí)現(xiàn)自適應(yīng)寬度的圓角菜單效果代碼,基于css實(shí)現(xiàn)自適應(yīng)寬度的圓角菜單效果,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-09-21CSS實(shí)現(xiàn)自適應(yīng)寬度的菜單按鈕效果代碼
這篇文章主要為大家介紹了CSS實(shí)現(xiàn)自適應(yīng)寬度的菜單按鈕效果代碼,實(shí)例分析了css針對(duì)頁(yè)面自適應(yīng)寬度的相關(guān)設(shè)置技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-11- 這篇文章主要介紹了CSS中固定寬度布局的詳細(xì)教程,包括元素內(nèi)邊距和邊框等各種復(fù)雜的調(diào)試示例,極力推薦!需要的朋友可以參考下2015-07-23
CSS中的line-height行高屬性的使用技巧小結(jié)
這篇文章主要介紹了CSS中的line-height屬性的使用技巧,文中同時(shí)給出了line-height使用中經(jīng)常出現(xiàn)的文字重疊問(wèn)題的解決方法,需要的朋友可以參考下2016-02-02- 這篇文章主要介紹了CSS中行高line-height屬性的一些使用技巧,包括為每行文本指定不同顏色和文本中間添加線時(shí)用到的一些操作方法,需要的朋友可以參考下2015-08-21
CSS 控制Html頁(yè)面高度導(dǎo)致抖動(dòng)問(wèn)題的原因
CSS 控制Html頁(yè)面高度導(dǎo)致抖動(dòng),這類由高度導(dǎo)致頁(yè)面抖動(dòng)的問(wèn)題,其實(shí)究其根本原因是滾動(dòng)條是否顯示導(dǎo)致的2014-08-11- 本文介紹下css中的line-height屬性的用法,通過(guò)實(shí)例學(xué)習(xí)css line-height屬性的具體用法,感興趣的朋友參考下2014-08-02
- 這篇文章主要介紹了在不定寬高的情況下,div內(nèi)圖片如何垂直居中,css樣式如何書寫?示例代碼如下2014-07-09