首頁 > web前端 > css教學 > 主體

模擬相容性的 inline-block 屬性_經驗交流

WBOY
發布: 2016-05-16 12:06:15
原創
1380 人瀏覽過

而現在對於 inline-block 屬性運用的需求也越來越多,可惜依舊只有 Firefox3 beta、IE8 beta、Opera、Safari 支援 inline-block 屬性(註:原來只有 Opera、Safari IE觸發 hasLayout 來模擬,Firefox2 有-moz-inline-box 和 -moz-inline-stack 私有屬性(這兩個屬性的比較引用自秦歌的《display:inline-block的應用兩例》)。

在實際應用中 -moz-inline-box 會存在元素間的對齊等問題,雖然 Firefox 還有一個私有屬性 -moz-box-align 來幫助解決對齊問題,但依舊難以預料問題多多,而相對來說 -moz-inline-stack 的表現更像 inline-block ,這點可以在 Firefox3 中測試出來。但 -moz-inline-stack 使用時也會有一個 bug ,如果一個 display:-moz-inline-stack; 的元素外層元素是 display:inline; 即會使 Firefox 中其所包含的連結不可點,這個需要用 position:relative; 來解決。

最終我們模擬的程式碼如下:

複製程式碼 程式碼如下:
display:inline-block; /*Firefox3 beta、IE8 beta、Opera、Safari 支持,IE 下觸發 inline 元素的 hasLayout*/
display:-moz-inline-stack; / Layout*/
display:-moz-inline-stack; /* 1ox可以用 -moz-inline-box */

zoom:1; /*IE 下觸發 hasLayout*/
*display:inline; /*一旦IE 下觸發了 hasLayout,設定 block 會使 display:inline 效果與 display:inline-block 相似*/

text-indent:-9999px;
*text-indent:0;
font-size:0;
line-height:0; /* 如需隱藏文字,可用這四個屬性 */
/*另外上面隱藏文字,還可以用更簡化的方法:line-height:超級大值;font-size: 0; */

overflow:hidden; /* 隱藏溢出的內容 */

vertical-align:middle; /* 行內垂直居中,針對 Opera 比較大的偏離 */

width:? px; /*?為任意非auto值*/
height:? px; /*?為任意非auto值*/
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!