CSS之使用display: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
了。
相關文章
- CSS display: flex佈局CSSFlex
- CSS:彈性佈局(display:flex)CSSFlex
- css32 CSS Layout - display: inline-blockCSSS3inlineBloC
- 使用 CSS columns 佈局來實現自動分組佈局CSS
- CSS之居中佈局CSS
- CSS 來佈局圖片CSS
- css之displayCSS
- display:flex 彈性佈局Flex
- 淺談CSS3中display屬性的Flex佈局CSSS3Flex
- 前端css佈局之BFC前端CSS
- CSS系列之常用佈局CSS
- CSS:三欄佈局之雙飛翼佈局CSS
- 淺談CSS3中display屬性的Flex佈局(轉)CSSS3Flex
- CSS3實現瀑布流佈局(display: flex/column-coCSSS3Flex
- CSS 三欄佈局之聖盃佈局和雙飛翼佈局CSS
- css佈局-float佈局CSS
- CSS佈局 --- 居中佈局CSS
- CSS之寬高比例佈局CSS
- CSS3之flex佈局CSSS3Flex
- 面試之道之 CSS 佈局面試CSS
- css之彈性佈局(flex)CSSFlex
- CSS display屬性的表格佈局相關屬性的解釋CSS
- 【css】佈局CSS
- css 佈局CSS
- CSS佈局CSS
- 佈局之: flex(CSS3新增)FlexCSSS3
- display:block display:inline-block 的屬性、呈現和作用BloCinline
- CSS display顯示分別為block、 inline、 inline-block的三種元素CSSBloCinline
- CSS佈局之三欄佈局CSS
- CSS佈局 --- 自適應佈局CSS
- CSS佈局 --- 等寬&等高佈局CSS
- CSS 佈局之水平居中佈局CSS
- CSS佈局–聖盃佈局和雙飛翼佈局以及使用Flex實現聖盃佈局CSSFlex
- display:table-cell自適應佈局
- 微信小程式CSS之Flex佈局微信小程式CSSFlex
- CSS 佈局模式CSS模式
- CSS 佈局模型CSS模型
- css佈局方法CSS