CSS之使用display:inline-block來布局 2018-11-07

css之display:inline-block布局

1.解釋一下display的幾個常用的屬性值,inline , block, inline-block

inline:

使元素變成行內(nèi)元素,擁有行內(nèi)元素的特性,即可以與其他行內(nèi)元素共享一行,不會獨占一行.?

不能更改元素的height,width的值,大小由內(nèi)容撐開.?

可以使用padding,margin的left和right產(chǎn)生邊距效果,但是top和bottom就不行.

block:

使元素變成塊級元素,獨占一行,在不設(shè)置自己的寬度的情況下,塊級元素會默認填滿父級元素的寬度.?

能夠改變元素的height,width的值.?

可以設(shè)置padding,margin的各個屬性值,top,left,bottom,right都能夠產(chǎn)生邊距效果.

inline-block:

結(jié)合了inline與block的一些特點,結(jié)合了上述inline的第1個特點和block的第2,3個特點.

用通俗的話講,就是不獨占一行的塊級元素。如圖:

圖一:

圖二:

兩個圖可以看出,display:inline-block后塊級元素能夠在同一行顯示,有人這說不就像浮動一樣嗎。沒錯,display:inline-block的效果幾乎和浮動一樣,但也有不同,接下來講一下inline-block和浮動的比較。


2.inline-block布局 vs 浮動布局

? ? a.不同之處:對元素設(shè)置display:inline-block ,元素不會脫離文本流,而float就會使得元素脫離文本流,且還有父元素高度坍塌的效果

? ? b.相同之處:能在某程度上達到一樣的效果

我們先來看看這兩種布局:

圖一:display:inline-block

圖二:對兩個孩子使用float:left,我在上一篇浮動布局講過,這是父元素會高度坍塌,所以要閉合浮動,對box使用overflow:hidden,效果如下:

>>乍一看兩個都能做到幾乎相同的效果,(仔細看看display:inline-block中有間隙問題,這個留到下面再講)

  c.浮動布局不太好的地方:參差不齊的現(xiàn)象,我們看一個效果:

圖三:?

圖四:?

>>從圖3,4可以看出浮動的局限性在于,若要元素排滿一行,換行后還要整齊排列,就要子元素的高度一致才行,不然就會出現(xiàn)圖三的效果,而inline-block就不會。


3.inline-block存在的小問題:

  a.上面可以看到用了display:inline-block后,存在間隙問題,間隙為4像素,這個問題產(chǎn)生的原因是換行引起的,因為我們寫標簽時通常會在標簽結(jié)束符后順手打個回車,而回車會產(chǎn)生回車符,回車符相當于空白符,通常情況下,多個連續(xù)的空白符會合并成一個空白符,而產(chǎn)生“空白間隙”的真正原因就是這個讓我們并不怎么注意的空白符。


  b.去除空隙的方法:

1.對父元素添加,{font-size:0},即將字體大小設(shè)為0,那么那個空白符也變成0px,從而消除空隙

現(xiàn)在這種方法已經(jīng)可以兼容各種瀏覽器,以前chrome瀏覽器是不兼容的

圖一:


  c.瀏覽器兼容性:ie6/7是不兼容 display:inline-block的所以要額外處理一下:

在ie6/7下:

對于行內(nèi)元素直接使用{dislplay:inline-block;}

對于塊級元素:需添加{display:inline;zoom:1;}


4.總結(jié):

display:inline-block的布局方式和浮動的布局方式,究竟使用哪個,我覺得應(yīng)該根據(jù)實際情況來決定的:

a.對于橫向排列東西來說,我更傾向與使用inline-block來布局,因為這樣清晰,也不用再像浮動那樣清除浮動,害怕布局混亂等等。

b.對于浮動布局就用于需要文字環(huán)繞的時候,畢竟這才是浮動真正的用武之地,水平排列的是就交給inline-block了。


作者:Ry-yuan

如需轉(zhuǎn)載請標明出處,本文地址:http://www.cnblogs.com/Ry-yuan/p/6848197.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽?zāi)J的外補...
    _Yfling閱讀 14,152評論 1 92
  • 1. 前言 前端圈有個“?!保涸诿嬖嚂r,問個css的position屬性能刷掉一半人,其中不乏工作四五年的同學。在...
    YjWorld閱讀 4,912評論 5 15
  • css之display:inline-block布局 1.解釋一下display的幾個常用的屬性值,inline ...
    凌亂的跳蚤閱讀 348評論 0 0
  • CSS 是什么 css(Cascading Style Sheets),層疊樣式表,選擇器{屬性:值;屬性:值}h...
    崔敏嫣閱讀 1,577評論 0 5
  • 一、肯定法:你真棒,你答應(yīng)老師9點半上傳作業(yè)的結(jié)果還提前交了,你很講信用說到做到。 二、改變法 1、接受:中文作業(yè)...
    c008f621873d閱讀 108評論 0 0

友情鏈接更多精彩內(nèi)容