模擬相容性的 inline block 屬性

2021-09-24 18:42:38 字數 1574 閱讀 6250

一年前網上還找不到關於 inline-block 屬性的文章,為了方便大家更好的理解該屬性,當時總結整理了篇《display:inline-block的深入理解》。

而現在對於 inline-block 屬性運用的需求也越來越多,可惜依舊只有 firefox3 beta、ie8 beta、opera、safari 支援 inline-block 屬性(注:原來只有 opera、safari 支援),但 ie6、ie7 可以通過觸發 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

;/* firefox 的私有屬性,也可以用 -moz-inline-box */

zoom:1

;/*ie 下觸發 haslayout*/

*display

:inline

;/*一旦ie 下觸發了 haslayout,設定 block 元素為 inline 會使 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值*/

相容性(空格相容性)

在chrome與firefox下顯示的寬度不同,原因是兩個瀏覽器的預設字型不同,給html規定字型即可解決。下面有各種形式的空格,各有不同 不換行空格,按下空格鍵所產生的空格,受字型影響明顯 ensp 半形空格 em寬度的一半 乙個小寫字母的寬度 基本不受字型影響 emsp 全形空格 乙個em寬度 ...

相容性小結

1.不同瀏覽器的標籤預設的外補丁和內補丁不同。解決 2.chorme瀏覽器下字型最小12px 解決 font size 12px webkit transform origin x 0 webkit transform scale 0.5833333333333334 scale 12 3.ie瀏覽...

程式相容性

版本可以提供各種不同形式的相容性 源 相容性,鏈結相容性,執行相容性,和程序相容性。這些都是根據c 程式建立各個過程命名的,1 如果沒有使用者需要重新編譯任何 那麼程式庫的版本n和版本m就具有源 相容性 2 如果沒有使用者需要重新編譯任何目標檔案,那麼版本n和版本m就具有鏈結相容性 3 如果沒有任何...