CSS兩列以及三列自適應(yīng)布局方法整理

參考:
https://www.cnblogs.com/depsi/p/5097013.html
https://blog.csdn.net/qq_40072782/article/details/82927573

一君仆、兩欄布局:左側(cè)定寬蛛芥,右側(cè)自適應(yīng)

方法一:利用絕對(duì)定位

右側(cè)設(shè)置絕對(duì)定位,將其從文檔流中刪除墨榄,為其設(shè)置100%的寬度和left的值(為左側(cè)定寬留出位置)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .sitebar{
            width: 200px;
            background-color: green;
        }
        .content{
            position: absolute;
            left: 200px;
            right: 0;
            top: 0;
            background-color: red;
        }
    </style>
</head>
<body>
    <div class="content">右側(cè)主體自適應(yīng)區(qū)塊</div>
    <div class="sitebar">左側(cè)定寬200px區(qū)塊</div>
</body>
</html>

方法二:浮動(dòng)法(和后面三列的思路一樣)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .sitebar{
            float: left;
            width: 200px;
            background-color: green;
        }
        .content{
            background-color: red;
            margin-left: 200px;
        }
    </style>
</head>
<body>
    <div class="sitebar">左側(cè)定寬200px區(qū)塊</div>
    <div class="content">右側(cè)主體自適應(yīng)區(qū)塊</div>
</body>
</html>

優(yōu)點(diǎn):代碼簡(jiǎn)潔草冈,便于理解
缺點(diǎn):不利于頁(yè)面優(yōu)化试和,右側(cè)主內(nèi)容區(qū)后加載

方法三:margin負(fù)值法

該方法在網(wǎng)站布局中非常常見正罢,也是面試撤フ考點(diǎn)映胁,優(yōu)點(diǎn)是三欄相互關(guān)聯(lián)木羹,有一定的抗性。
要求:在middle外部再加一個(gè)div解孙。此div需要設(shè)置float屬性使其形成一個(gè)BFC坑填,并設(shè)置寬度,并且這個(gè)寬度要和left弛姜、right塊的margin負(fù)值進(jìn)行配合脐瑰。看代碼吧

方法四:css3新屬性flex方法

寫一個(gè)<div>廷臼,在flex中類似于容器苍在,
將left、right荠商、middle全部包進(jìn)去
并設(shè)div的display:flex寂恬。
middle塊的樣式中加上flex:1(或者auto)

三列布局

方法一:利用絕對(duì)定位:左右兩列固定寬度,使用絕對(duì)定位

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>三列自適應(yīng)布局 左右絕對(duì)定位absolute</title>
<style type="text/css">
    *{
        padding: 0;margin: 0;
    }
    .left{
        width: 200px;
        height: 200px;
        background: yellow;
        position: absolute; 
        top: 0;
        left: 0;   //注意這里
    }

    .right{
        width: 200px;
        height: 200px;
        background: blue;
        position: absolute;
        top: 0;
        right: 0;   //注意這里
        
    }
    .middle{
        height: 200px;
        background: red;
        text-align: center;
       
    }

 
</style>
</head>
<body>
<div class="middle">middle</div>
<div class="left">left</div>
<div class="right">right</div>

</body>
</html>

方法二:浮動(dòng)法

浮動(dòng)法的原理:
對(duì)左右塊使用分別使用float:left和float:right莱没,float使左右兩個(gè)元素脫離文檔流初肉,中間元素在正常文檔流中。
注意:
middle位置要求:middle塊一定要放在left和right之后饰躲,因?yàn)樗紦?jù)文檔流位置牙咏,所以一定要放在最后

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>三列自適應(yīng)布局 左右絕對(duì)定位absolute</title>
<style type="text/css">
    *{
        padding: 0;margin: 0;
    }
    .left{
        width: 200px;
        height: 200px;
        background: yellow;
        float: left;
    }

    .right{
        width: 200px;
        height: 200px;
        background: blue;
        float: right;   
    }
    .middle{
        height: 200px;
        background: red;
        text-align: center;
       
    }
</style>
</head>
<body>

<div class="left">left</div>
<div class="right">right</div>
<div class="middle">middle</div>

</body>
</html>

方法三:margin負(fù)值法

該方法在網(wǎng)站布局中非常常見,也是面試赤诹眩考點(diǎn)妄壶,優(yōu)點(diǎn)是三欄相互關(guān)聯(lián),有一定的抗性焦蘑。
要求:在middle外部再加一個(gè)div。此div需要設(shè)置float屬性使其形成一個(gè)BFC盒发,并設(shè)置寬度例嘱,并且這個(gè)寬度要和left、right塊的margin負(fù)值進(jìn)行配合宁舰∑绰眩看代碼吧

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>document</title>
<style type="text/css">
    *{
        padding: 0;margin: 0;
    }

    .main{
        width: 100%;
        height: 200px;
        background: blue;
        float: left;  /*記得是包含middle外層的div設(shè)置浮動(dòng)*/
    }

    .left{
        width: 200px;
        height: 200px;
        background: yellow;
        float: left;
        margin-left: -100%;  /*-100%是因?yàn)橄鄬?duì)來(lái)說(shuō)它偏移到下一行去了*/
    }

    .right{
        width: 300px;
        height: 200px;
        background: blue;
        float: left;
        margin-left: -300px;  /*這里要設(shè)置成right寬度的負(fù)值*/
        
    }
    .middle{
        height: 200px;
        background: red;
        text-align: center;
    }

</style>
</head>
<body>
<div class="main">
    <div class="middle">middle</div>
</div>
<div class="left">left</div>
<div class="right">right</div>
    
</body>
</html>

方法四:css3新屬性flex方法

寫一個(gè)<div>,在flex中類似于容器蛮艰,
將left腋腮、right、middle全部包進(jìn)去
并設(shè)div的display:flex。
middle塊的樣式中加上flex:1(或者auto)

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>三列自適應(yīng)布局 css3新屬性flex方法</title>
<style type="text/css">
  #box{
    width: 100%;
    height: 200px;
    display: flex;
  }
  #left,#right{
    width: 200px;
    height: 200px;
    background: pink;
  }
  #middle{
    flex: auto;  /* flex屬性是flex-grow(項(xiàng)目放大比例), flex-shrink(縮小比例) 和 flex-basis的簡(jiǎn)寫即寡,默認(rèn)值為0 1 auto徊哑。后兩個(gè)屬性可選*/
    background: skyblue;
  }

</style>
</head>
<body>
<!-- 寫一個(gè)的div包含left、right聪富、middle莺丑,設(shè)置為display:flex;并將middle設(shè)置flex:1墩蔓; -->
<div id="box">
<div id="left">left</div>
<div id="middle">middle </div>
<div id="right">right</div>
</div>
</body>
</html>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末梢莽,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子奸披,更是在濱河造成了極大的恐慌昏名,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,640評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阵面,死亡現(xiàn)場(chǎng)離奇詭異轻局,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)膜钓,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門嗽交,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人颂斜,你說(shuō)我怎么就攤上這事夫壁。” “怎么了沃疮?”我有些...
    開封第一講書人閱讀 165,011評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵盒让,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我司蔬,道長(zhǎng)邑茄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,755評(píng)論 1 294
  • 正文 為了忘掉前任俊啼,我火速辦了婚禮肺缕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘授帕。我一直安慰自己同木,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,774評(píng)論 6 392
  • 文/花漫 我一把揭開白布跛十。 她就那樣靜靜地躺著彤路,像睡著了一般。 火紅的嫁衣襯著肌膚如雪芥映。 梳的紋絲不亂的頭發(fā)上洲尊,一...
    開封第一講書人閱讀 51,610評(píng)論 1 305
  • 那天远豺,我揣著相機(jī)與錄音,去河邊找鬼坞嘀。 笑死躯护,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的姆吭。 我是一名探鬼主播榛做,決...
    沈念sama閱讀 40,352評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼内狸!你這毒婦竟也來(lái)了检眯?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,257評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤昆淡,失蹤者是張志新(化名)和其女友劉穎锰瘸,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體昂灵,經(jīng)...
    沈念sama閱讀 45,717評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡避凝,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,894評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了眨补。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片管削。...
    茶點(diǎn)故事閱讀 40,021評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖撑螺,靈堂內(nèi)的尸體忽然破棺而出含思,到底是詐尸還是另有隱情,我是刑警寧澤甘晤,帶...
    沈念sama閱讀 35,735評(píng)論 5 346
  • 正文 年R本政府宣布含潘,位于F島的核電站,受9級(jí)特大地震影響线婚,放射性物質(zhì)發(fā)生泄漏遏弱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,354評(píng)論 3 330
  • 文/蒙蒙 一塞弊、第九天 我趴在偏房一處隱蔽的房頂上張望漱逸。 院中可真熱鬧,春花似錦游沿、人聲如沸饰抒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,936評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)循集。三九已至唇敞,卻和暖如春蔗草,著一層夾襖步出監(jiān)牢的瞬間咒彤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,054評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工咒精, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留镶柱,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,224評(píng)論 3 371
  • 正文 我出身青樓模叙,卻偏偏與公主長(zhǎng)得像歇拆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子范咨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,974評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 問(wèn)答題47 /72 常見瀏覽器兼容性問(wèn)題與解決方案故觅? 參考答案 (1)瀏覽器兼容問(wèn)題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,754評(píng)論 1 92
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標(biāo)準(zhǔn)渠啊。 注意:講述HT...
    kismetajun閱讀 27,486評(píng)論 1 45
  • 一输吏、CSS入門 1、css選擇器 選擇器的作用是“用于確定(選定)要進(jìn)行樣式設(shè)定的標(biāo)簽(元素)”替蛉。 有若干種形式的...
    寵辱不驚丶?xì)q月靜好閱讀 1,596評(píng)論 0 6
  • DC的新超級(jí)英雄電視劇《泰坦》在公開了制作陣容之后就吸引了眾多網(wǎng)友的期待贯溅,官方在公開了夜翼的劇照之后更是引發(fā)了眾多...
    二次元冒險(xiǎn)團(tuán)閱讀 1,024評(píng)論 0 0
  • 關(guān)于愛情,神圣躲查,美好它浅,幸福。仿佛多漂亮的文字都描述不出它的好镣煮,它的美姐霍,它的意義。 我總說(shuō)怎静,我不相信...
    阿蕪閱讀 179評(píng)論 1 2