日本免费全黄少妇一区二区三区-高清无码一区二区三区四区-欧美中文字幕日韩在线观看-国产福利诱惑在线网站-国产中文字幕一区在线-亚洲欧美精品日韩一区-久久国产精品国产精品国产-国产精久久久久久一区二区三区-欧美亚洲国产精品久久久久

text-align:justify實現(xiàn)文本兩端對齊兼容IE

對于text-align 我們再熟悉不過了,可是它有個justify屬性,平時很少用到,就鮮為人知了 。justify是一種文本靠兩邊布局方式,一般應(yīng)用于書刊雜志排版;合理運用text-align:justify 有時會省去很多開發(fā)的時間 。
要想更好的理解 css,尤其是 IE 下對 css 的渲染,haslayout 是一個非常有必要徹底弄清楚的概念 。大多 IE
下的顯示錯誤,就是源于 haslayout 。
什么是 haslayout ?
haslayout 是Windows Internet Explorer渲染引擎的一個內(nèi)部組成部分 。在Internet Explorer中,一個元素要么自己對自身的內(nèi)容進(jìn)行計算大小和組織,要么依賴于父元素來計算尺寸和組織內(nèi)容 。為了調(diào)節(jié)這兩個不同的概念,渲染引擎采用了 hasLayout 的屬性,屬性值可以為true或false 。當(dāng)一個元素的 hasLayout 屬性值為true時,我們說這個元素有一個布局(layout)
當(dāng)一個元素有一個布局時,它負(fù)責(zé)對自己和可能的子孫元素進(jìn)行尺寸計算和定位 。簡單來說,這意味著這個元素需要花更多的代價來維護(hù)自身和里面的內(nèi)容,而不是依賴于祖先元素來完成這些工作 。因此,一些元素默認(rèn)會有一個布局 。
當(dāng)我們說一個元素“擁有l(wèi)ayout”或“得到layout”,或者說一個元素“has layout” 的時候,我們的意思是指它的微軟專有屬性 hasLayout 被設(shè)為了 true。
【text-align:justify實現(xiàn)文本兩端對齊兼容IE】一個“l(fā)ayout元素”可以是一個默認(rèn)就擁有 layout 的元素或者是一個通過設(shè)置某些 CSS 屬性得到 layout 的元素 。通過 IE Developer Toolbar 可以查看 IE 下 HTML 元素是否擁有haslayout,在 IE Developer Toolbar 下,擁有 haslayout 的元素,通常顯示為“haslayout = -1” 。
特別注意的是,hasLayout 在 IE 8 及之后的 IE 版本中已經(jīng)被拋棄,所以在實際開發(fā)中只需針對 IE 8 以下的瀏覽器為某些元素觸發(fā) hasLayout。
一個元素觸發(fā) hasLayout 會影響一個元素的尺寸和定位,這樣會消耗更多的系統(tǒng)資源,因此 IE 設(shè)計者默認(rèn)只為一部分的元素觸發(fā) hasLayout (即默認(rèn)有部分元素會觸發(fā) hasLayout ,這與 BFC 基本完全由開發(fā)者通過特定 CSS 觸發(fā)并不一樣),這部分元素如下:

text-align:justify實現(xiàn)文本兩端對齊兼容IE


如何激發(fā) haslayout?
大部分的 IE 顯示錯誤,都可以通過激發(fā)元素的 haslayout 屬性來修正 ??梢酝ㄟ^設(shè)置 css 尺寸屬性(width/height)等來激發(fā)元素的 haslayout,使其“擁有布局” 。
如下所示,通過設(shè)置以下 css 屬性即可 。
* display: inline-block
* height: (任何值除了auto)
* float: (left 或 right)
* position: absolute
* width: (任何值除了auto)
* writing-mode: tb-rl
* zoom: (除 normal 外任意值)
Internet Explorer 7 還有一些額外的屬性(不完全列表):
* min-height: (任意值)
* max-height: (除 none 外任意值)
* min-width: (任意值)
* max-width: (除 none 外任意值)
* overflow: (除 visible 外任意值)
* overflow-x: (除 visible 外任意值)
* overflow-y: (除 visible 外任意值)
* position: fixed
其中 overflow-x 和 overflow-y 是 css3 盒模型中的屬性,目前還未被瀏覽器廣泛支持 。
對于內(nèi)聯(lián)元素(默認(rèn)即為內(nèi)聯(lián)的元素,如 span,或 display:inline; 的元素),
width 和 height 只在 IE5.x 下和 IE6 或更新版本的 quirks 模式下觸發(fā) hasLayout。而對于 IE6,如果瀏覽器運行于標(biāo)準(zhǔn)兼容模式下,內(nèi)聯(lián)元素會忽略 width 或 height 屬性,所以設(shè)置 width 或 height 不能在此種情況下令該元素具有 layout 。
zoom 總是可以觸發(fā) hasLayout,但是在 IE5.0 中不支持 。建議使用 zoom: 1 來觸發(fā)元素的 hasLayout。
具有“l(fā)ayout” 的元素如果同時 display: inline ,那么它的行為就和標(biāo)準(zhǔn)中所說的 inline-block 很類似了:在段落中和普通文字一樣在水平方向和連續(xù)排列,受 vertical-align 影響,并且大小可以根據(jù)內(nèi)容自適應(yīng)調(diào)整 。這也可以解釋為什么單單在 IE/Win 中內(nèi)聯(lián)元素可以包含塊級元素而少出問題,因為在別的瀏覽器中 display: inline 就是內(nèi)聯(lián),不像 IE/Win 一旦內(nèi)聯(lián)元素?fù)碛?layout 還會變成 inline-block 。

推薦閱讀