inline
常用的inline就是文字和圖片,其實inline真沒什么好說的,大家可以把它想象成一個杯子里的水,它是“流”,是沒有大小和形狀的,它的寬度取決於父容器的寬度。
因此,針對inline的標簽,你設置寬度和高度是無效的,通過監控可以知道,該元素實際的寬度和高度都是auto,並不是我們設定的值。

一個很基礎的問題:如何把inline元素轉換成“塊”元素?相信絕大部分人的回答是display:block,但是你應該知道這不是一個唯一的答案。至少我設置display:table也是可以的吧?
還有兩種情況你應該去了解(如果你不知道的話):
第一,對inline元素設置float
還是剛才那個例子,我們對span元素添加一個float:left,運行看看效果,你就會大吃一驚。從顯示的效果和監控的結果上看來,span元素已經“塊”化。注意,上一節剛剛講完float,不要忘記float的“破壞性”、“包裹性”,在這里同樣適用。

第二,對inline元素設置position:absolute/fixed
還是有同一個例子做演示,這次在span元素上加上absolute/fixed,效果大家應該能猜到,和加上float的效果相同。至於absolute/fixed有什么特性,會在下一節介紹position時提到。

3. block
本系列有一節重點講解了《盒子模型》,不知道大家看沒看過,或者說你已經很了解盒子模型了。
其實對於block,我覺得就是“盒子模型”。一個元素設置了block,它就必須遵循盒子模型的規則。因此,這里也不再去詳細寫它了,大家可以去盒子模型那一節好好看看,就那么點內容。
4. inline-block
這個話題還得從《瀏覽器默認樣式》這一節開始。瀏覽器默認樣式中規定了幾個html元素為display:inline-block,回顧一下。

初學者對於inline-block可能比較陌生,沒關系,一步一步來。首先,你應該知道inline是什么樣子的,就是一般的文字、圖片;其次,你應該知道block是什么樣子的,一般的div就是;最后,inline-block顧名思義,它既有inline的特性,又有block的特性,大家可以想想一般的button、input是什么樣子的。
那button舉例子。我們在頁面中輸入若干個<button>,發現它們是“流”式排列的(可以對比一下若干個<div>的排列方式)。但是針對一個button,我們還可以自定義修改它的形狀,這樣就有“塊”的特征。

因此,inline-block的特點可以總結為:外部看來是“流”,但是自身確實一個“塊”。不知道大家理解也無?
1.解釋一下display的幾個常用的屬性值,inline , block, inline-block
- inline:
- 使元素變成行內元素,擁有行內元素的特性,即可以與其他行內元素共享一行,不會獨占一行.
- 不能更改元素的height,width的值,大小由內容撐開.
- 可以使用padding,margin的left和right產生邊距效果,但是top和bottom就不行.
- block:
- 使元素變成塊級元素,獨占一行,在不設置自己的寬度的情況下,塊級元素會默認填滿父級元素的寬度.
- 能夠改變元素的height,width的值.
- 可以設置padding,margin的各個屬性值,top,left,bottom,right都能夠產生邊距效果.
- inline-block:
- 結合了inline與block的一些特點,結合了上述inline的第1個特點和block的第2,3個特點.
- 用通俗的話講,就是不獨占一行的塊級元素。如圖:
圖一:
圖二:
兩個圖可以看出,display:inline-block后塊級元素能夠在同一行顯示,有人這說不就像浮動一樣嗎。沒錯,display:inline-block的效果幾乎和浮動一樣,但也有不同,接下來講一下inline-block和浮動的比較。
2.inline-block布局 vs 浮動布局
a.不同之處:對元素設置display:inline-block ,元素不會脫離文本流,而float就會使得元素脫離文本流,且還有父元素高度坍塌的效果
b.相同之處:能在某程度上達到一樣的效果
我們先來看看這兩種布局:
圖一:display:inline-block
圖二:對兩個孩子使用float:left,我在上一篇浮動布局講過,這是父元素會高度坍塌,所以要閉合浮動,對box使用overflow:hidden,效果如下:
>>乍一看兩個都能做到幾乎相同的效果,(仔細看看display:inline-block中有間隙問題,這個留到下面再講)
c.浮動布局不太好的地方:參差不齊的現象,我們看一個效果:
圖三: 
圖四: 
>>從圖3,4可以看出浮動的局限性在於,若要元素排滿一行,換行后還要整齊排列,就要子元素的高度一致才行,不然就會出現圖三的效果,而inline-block就不會。
3.inline-block存在的小問題:
a.上面可以看到用了display:inline-block后,存在間隙問題,間隙為4像素,這個問題產生的原因是換行引起的,因為我們寫標簽時通常會在標簽結束符后順手打個回車,而回車會產生回車符,回車符相當於空白符,通常情況下,多個連續的空白符會合並成一個空白符,而產生“空白間隙”的真正原因就是這個讓我們並不怎么注意的空白符。
b.去除空隙的方法:
1.對父元素添加,{font-size:0},即將字體大小設為0,那么那個空白符也變成0px,從而消除空隙
現在這種方法已經可以兼容各種瀏覽器,以前chrome瀏覽器是不兼容的
圖一:
c.瀏覽器兼容性:ie6/7是不兼容 display:inline-block的所以要額外處理一下:
在ie6/7下:
對於行內元素直接使用{dislplay:inline-block;}
對於塊級元素:需添加{display:inline;zoom:1;}
4.總結:
display:inline-block的布局方式和浮動的布局方式,究竟使用哪個,我覺得應該根據實際情況來決定的:
a.對於橫向排列東西來說,我更傾向與使用inline-block來布局,因為這樣清晰,也不用再像浮動那樣清除浮動,害怕布局混亂等等。
b.對於浮動布局就用於需要文字環繞的時候,畢竟這才是浮動真正的用武之地,水平排列的是就交給inline-block了。
