一年前網(wǎng)上還找不到關(guān)于 inline-block 屬性的文章,為了方便大家更好的理解該屬性,當(dāng)時(shí)總結(jié)整理了篇《display:inline-block的深入理解》。
而現(xiàn)在對于 inline-block 屬性運(yùn)用的需求也越來越多,可惜依舊只有 Firefox3 beta、IE8 beta、Opera、Safari 支持 inline-block 屬性(注:原來只有 Opera、Safari 支持),但 IE6、IE7 可以通過觸發(fā) hasLayout 來模擬,F(xiàn)irefox2 有-moz-inline-box 和 -moz-inline-stack 私有屬性(這兩個(gè)屬性的比較引用自秦歌的《display:inline-block的應(yīng)用兩例》)。
在實(shí)際應(yīng)用中 -moz-inline-box 會存在元素間的對齊等問題,雖然 Firefox 還有一個(gè)私有屬性 -moz-box-align 來幫助解決對齊問題,但依舊難以預(yù)料問題多多,而相對來說 -moz-inline-stack 的表現(xiàn)更像 inline-block ,這點(diǎn)可以在 Firefox3 中測試出來。但 -moz-inline-stack 使用時(shí)也會有一個(gè) bug ,如果一個(gè) display:-moz-inline-stack; 的元素外層元素是 display:inline; 即會使 Firefox 中其包含的鏈接不可點(diǎn),這個(gè)需要用 position:relative; 來解決。
最終我們模擬的代碼如下:
display:inline-block; /*Firefox3 beta、IE8 beta、Opera、Safari 支持,IE 下觸發(fā) inline 元素的 hasLayout*/
display:-moz-inline-stack; /* Firefox 的私有屬性,也可以用 -moz-inline-box */
zoom:1; /*IE 下觸發(fā) hasLayout*/
*display:inline; /*一旦IE 下觸發(fā)了 hasLayout,設(shè)置 block 元素為 inline 會使 display:inline 效果與 display:inline-block 相似*/
text-indent:-9999px;
*text-indent:0;
font-size:0;
line-height:0; /* 如需隱藏文字,可用這四個(gè)屬性 */
/*另外上面隱藏文字,還可以用更簡化的方法:line-height:超級大值;font-size:0; */
overflow:hidden; /* 隱藏溢出的內(nèi)容 */
vertical-align:middle; /* 行內(nèi)垂直居中,針對 Opera 比較大的偏離 */
width:?px; /*?為任意非auto值*/
height:?px; /*?為任意非auto值*/