CSS布局方法及使用技巧

本文將介紹CSS的左右徐伐、左中右、水平募狂、垂直布局方法办素,還有一些CSS使用技巧角雷。我可要放大招啦!

左右布局

1.在目標(biāo)元素前float
2.引入clearfix
3.在目標(biāo)元素前加上clearfix

HTML代碼
<!--左右布局-->
    <div class="container-1 clearfix">
        <div class="leftbox">左側(cè)</div>
        <div class="rightbox">右側(cè)</div>
    </div>
CSS代碼
.clearfix::after{
    content: '';
    display: block;
    clear: both;
    }
    
.container-1 .leftbox{
    float: left;
    background: #77C3F2;
    width: 500px;
    height: 300px;
}
.container-1 .rightbox{
    float: left;
    background: #B6DBF2;
    width: 500px;
    height: 300px;
}
效果
左右布局

左中右布局

左中右布局與左右布局原理類似

HTML代碼
<!--左中右布局-->
    <div class="container-2 clearfix">
        <div class="leftBox">左側(cè)</div>
        <div class="midBox">中間</div>
        <div class="rightBox">右側(cè)</div>
    </div>
CSS代碼
.clearfix::after{
    content: '';
    display: block;
    clear: both;
    }
    
.container-2 .leftBox{
    float: left;
    background: #77C3F2;
    width: 300px;
    height: 300px;
}

.container-2 .midBox{
    float: left;
    background: #3A758C;
    width: 300px;
    height: 300px;
}

.container-2 .rightBox{
    float: left;
    background: #B6DBF2;
    width: 300px;
    height: 300px;
}
效果
左中右布局

水平居中布局

水平居中可以根據(jù)行內(nèi)元素性穿、定寬塊狀元素勺三、不定寬塊狀元素三種

1. 行內(nèi)元素水平居中

行內(nèi)元素要水平居中,可以通過在父級元素上設(shè)置text-align: center來實現(xiàn)

HTML代碼
<div class="container-3">
   <a href="#">行內(nèi)元素居中</a>
</div>
CSS代碼
.container-3 {
    text-align: center;
}
效果
行內(nèi)元素居中

2. 定寬塊狀元素水平居中

寬度確定的塊狀元素可以通過通過設(shè)置左右margin值為auto來實現(xiàn)居中

HTML
<div class="container-4">
   定寬塊狀元素
</div>
CSS
.container-4{
    width: 300px;
    height: 300px;/*高度非必須*/
    background: #FF6766;
    margin-left:auto;
    margin-right: auto;
}
效果
定寬塊狀元素水平居中

3. 不定寬塊狀元素水平居中

不定寬即寬度不確定需曾,面對這種塊狀元素可以通過更改塊狀元素的displayinline-block類型吗坚,再在父級元素上增加text-align: center來實現(xiàn)水平居中。但是這種布局方法呆万,會帶來一個新的問題商源,就是標(biāo)簽之間的換行符帶來的空白間距。解決方法大家可以參考這里《如何解決inline-block元素的空白間距》谋减。

HTML
   <div class="container-5">
       <ul>
               <li><a href="#">1</a></li>
               <li><a href="#">2</a></li>
               <li><a href="#">3</a></li>
       </ul>
   </div>
CSS
.container-5{
    text-align: center;
}
.container-5 li{
    display: inline-block;
} 
效果
不定寬塊狀元素水平居中

垂直居中布局

垂直居中也可以分為兩種情況:父元素高度確定的單行文本牡彻,父元素高度確定的多行文本。

1. 父元素高度確定的單行文本

只需將父元素的height與line-height設(shè)置為一直即可實現(xiàn)出爹。

HTML
    <div class="container-6">
        <h2>單行文本垂直居中</h2>
    </div>
CSS
.container-6 h2{
    height: 100px;
    line-height: 100px;
    background: #61AAE0
}   
效果
單行文本垂直居中

2. 父元素高度確定的多行文本庄吼、圖片

可以使用插入 table (包括tbody、tr严就、td)標(biāo)簽总寻,同時在父元素設(shè)置 vertical-align:middle

HTML
<table>
        <tbody><tr><td class="container-7">
        <div>
            <p>多行</p>
            <p>文本</p>
            <p>垂直</p>
            <p>居中</p>
        </div>
        </td></tr></tbody>
    </table>
CSS
/*td標(biāo)簽?zāi)J(rèn)就是vertical-align:middle梢为,所以無需再設(shè)置*/
table td{
    height: 300px;
    background:#BE81F7; 
}
效果
多行文本垂直居中

其他小技巧

  1. 終極技巧
    使用搜索引擎搜索:
    CSS 關(guān)鍵詞 trick
    CSS 效果 generator
  2. 實現(xiàn)圖片水平垂直局中且自適應(yīng)的方法
background-position: center center;
background-size: cover;
  1. 鼠標(biāo)懸停出現(xiàn)下劃線并且不會晃動的方法
/*給原來的元素增加一個相同的透明下劃線废菱,解決懸浮晃動問題*/
border-bottom: 1px solid transparent;
}
/*增加懸浮效果-下劃線*/
.topNavBar>nav>ul>li>a:hover{
border-bottom: 1px solid red;
}
  1. 解決距離邊框的上下距離不一致的解決辦法
vertical-align: top;

效果


邊框距離
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市抖誉,隨后出現(xiàn)的幾起案子殊轴,更是在濱河造成了極大的恐慌,老刑警劉巖袒炉,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件旁理,死亡現(xiàn)場離奇詭異,居然都是意外死亡我磁,警方通過查閱死者的電腦和手機孽文,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來夺艰,“玉大人芋哭,你說我怎么就攤上這事∮舾保” “怎么了减牺?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我拔疚,道長肥隆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任稚失,我火速辦了婚禮栋艳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘句各。我一直安慰自己吸占,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布凿宾。 她就那樣靜靜地躺著旬昭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪菌湃。 梳的紋絲不亂的頭發(fā)上问拘,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天,我揣著相機與錄音惧所,去河邊找鬼骤坐。 笑死,一個胖子當(dāng)著我的面吹牛下愈,可吹牛的內(nèi)容都是我干的纽绍。 我是一名探鬼主播,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼势似,長吁一口氣:“原來是場噩夢啊……” “哼拌夏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起履因,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤障簿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后栅迄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體站故,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年毅舆,在試婚紗的時候發(fā)現(xiàn)自己被綠了西篓。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡憋活,死狀恐怖岂津,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情悦即,我是刑警寧澤吮成,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布橱乱,位于F島的核電站,受9級特大地震影響赁豆,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜冗美,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一魔种、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧粉洼,春花似錦节预、人聲如沸姨裸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽披坏。三九已至闲昭,卻和暖如春框产,著一層夾襖步出監(jiān)牢的瞬間蜡娶,已是汗流浹背磅废。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工锅棕, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留拙泽,地道東北人。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓裸燎,卻偏偏與公主長得像顾瞻,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子德绿,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,658評論 2 350

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

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案荷荤? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補...
    _Yfling閱讀 13,737評論 1 92
  • 本文主要是起筆記的作用,內(nèi)容來自慕課網(wǎng). 認(rèn)識CSS樣式 CSS全稱為“層疊樣式表 (Cascading Styl...
    0o凍僵的企鵝o0閱讀 2,630評論 0 30
  • 什么是選擇器 每一條css樣式聲明(定義)由兩部分組成移稳,形式如下: 在{}之前的部分就是“選擇器”蕴纳,“選擇器”指明...
    小撓許閱讀 329評論 0 1
  • CSS格式化排版 1、字體 我們可以使用css樣式為網(wǎng)頁中的文字設(shè)置字體个粱、字號袱蚓、顏色等樣式屬性。下面我們來看一個例...
    張文靖同學(xué)閱讀 1,281評論 0 3
  • 每天在家里用播放器輕聲不間斷地播放瑜伽語音冥想曲几蜻,有意識喇潘,無意識的聆聽,不管你做家務(wù)梭稚、看書颖低、陪孩子、看電視弧烤、泡腳忱屑、...
    鈴木水一閱讀 3,110評論 1 5