• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

    text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊兼容IE_javascript技巧

    來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 21:42:24
    文檔

    text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊兼容IE_javascript技巧

    text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊兼容IE_javascript技巧:對(duì)于text-align 我們?cè)偈煜げ贿^了,可是它有個(gè)justify屬性,平時(shí)很少用到,就鮮為人知了。justify是一種文本靠兩邊布局方式,一般應(yīng)用于書刊雜志排版;合理運(yùn)用text-align:justify 有時(shí)會(huì)省去很多開發(fā)的時(shí)間。 要想更好的理解 css, 尤其是 IE 下對(duì)
    推薦度:
    導(dǎo)讀text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊兼容IE_javascript技巧:對(duì)于text-align 我們?cè)偈煜げ贿^了,可是它有個(gè)justify屬性,平時(shí)很少用到,就鮮為人知了。justify是一種文本靠兩邊布局方式,一般應(yīng)用于書刊雜志排版;合理運(yùn)用text-align:justify 有時(shí)會(huì)省去很多開發(fā)的時(shí)間。 要想更好的理解 css, 尤其是 IE 下對(duì)
    對(duì)于text-align 我們?cè)偈煜げ贿^了,可是它有個(gè)justify屬性,平時(shí)很少用到,就鮮為人知了。justify是一種文本靠兩邊布局方式,一般應(yīng)用于書刊雜志排版;合理運(yùn)用text-align:justify 有時(shí)會(huì)省去很多開發(fā)的時(shí)間。

    要想更好的理解 css, 尤其是 IE 下對(duì) css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清楚的概念。大多 IE
    下的顯示錯(cuò)誤,就是源于 haslayout。

    什么是 haslayout ?

    haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在Internet Explorer中,一個(gè)元素要么自己對(duì)自身的內(nèi)容進(jìn)行計(jì)算大小和組織,要么依賴于父元素來計(jì)算尺寸和組織內(nèi)容。為了調(diào)節(jié)這兩個(gè)不同的概念,渲染引擎采用了 hasLayout 的屬性,屬性值可以為true或false。當(dāng)一個(gè)元素的 hasLayout 屬性值為true時(shí),我們說這個(gè)元素有一個(gè)布局(layout)

    當(dāng)一個(gè)元素有一個(gè)布局時(shí),它負(fù)責(zé)對(duì)自己和可能的子孫元素進(jìn)行尺寸計(jì)算和定位。簡(jiǎn)單來說,這意味著這個(gè)元素需要花更多的代價(jià)來維護(hù)自身和里面的內(nèi)容,而不是依賴于祖先元素來完成這些工作。因此,一些元素默認(rèn)會(huì)有一個(gè)布局。

    當(dāng)我們說一個(gè)元素“擁有l(wèi)ayout”或“得到layout”,或者說一個(gè)元素“has layout” 的時(shí)候,我們的意思是指它的微軟專有屬性 hasLayout 被設(shè)為了 true 。

    一個(gè)“l(fā)ayout元素”可以是一個(gè)默認(rèn)就擁有 layout 的元素或者是一個(gè)通過設(shè)置某些 CSS 屬性得到 layout 的元素。通過 IE Developer Toolbar 可以查看 IE 下 HTML 元素是否擁有haslayout,在 IE Developer Toolbar 下,擁有 haslayout 的元素,通常顯示為“haslayout = -1”。

    特別注意的是,hasLayout 在 IE 8 及之后的 IE 版本中已經(jīng)被拋棄,所以在實(shí)際開發(fā)中只需針對(duì) IE 8 以下的瀏覽器為某些元素觸發(fā) hasLayout 。

    一個(gè)元素觸發(fā) hasLayout 會(huì)影響一個(gè)元素的尺寸和定位,這樣會(huì)消耗更多的系統(tǒng)資源,因此 IE 設(shè)計(jì)者默認(rèn)只為一部分的元素觸發(fā) hasLayout (即默認(rèn)有部分元素會(huì)觸發(fā) hasLayout ,這與 BFC 基本完全由開發(fā)者通過特定 CSS 觸發(fā)并不一樣),這部分元素如下:

    如何激發(fā) haslayout?

    大部分的 IE 顯示錯(cuò)誤,都可以通過激發(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 盒模型中的屬性,目前還未被瀏覽器廣泛支持。

    對(duì)于內(nèi)聯(lián)元素(默認(rèn)即為內(nèi)聯(lián)的元素,如 span,或 display:inline; 的元素),

    width 和 height 只在 IE5.x 下和 IE6 或更新版本的 quirks 模式下觸發(fā) hasLayout 。而對(duì)于 IE6,如果瀏覽器運(yùn)行于標(biāo)準(zhǔn)兼容模式下,內(nèi)聯(lián)元素會(huì)忽略 width 或 height 屬性,所以設(shè)置 width 或 height 不能在此種情況下令該元素具有 layout。
    zoom 總是可以觸發(fā) hasLayout,但是在 IE5.0 中不支持。建議使用 zoom: 1 來觸發(fā)元素的 hasLayout 。

    具有“l(fā)ayout” 的元素如果同時(shí) display: inline ,那么它的行為就和標(biāo)準(zhǔn)中所說的 inline-block 很類似了:在段落中和普通文字一樣在水平方向和連續(xù)排列,受 vertical-align 影響,并且大小可以根據(jù)內(nèi)容自適應(yīng)調(diào)整。這也可以解釋為什么單單在 IE/Win 中內(nèi)聯(lián)元素可以包含塊級(jí)元素而少出問題,因?yàn)樵趧e的瀏覽器中 display: inline 就是內(nèi)聯(lián),不像 IE/Win 一旦內(nèi)聯(lián)元素?fù)碛?layout 還會(huì)變成 inline-block。

    haslayout 問題的調(diào)試與解決

    當(dāng)網(wǎng)頁在 IE 中有異常表現(xiàn)時(shí),可以嘗試激發(fā) haslayout 來看看是不是問題所在。常用的方法是給某元素 css 設(shè)定 zoom:1 。使用 zoom:1 是因?yàn)榇蠖鄶?shù)情況下,它能在不影響現(xiàn)有環(huán)境的條件下激發(fā)元素的 haslayout。而一旦問題消失,那基本上就可以判斷是 haslayout 的原因。然后就可以通過設(shè)定相應(yīng)的 css 屬性來對(duì)這個(gè)問題進(jìn)行修正了。建議首先要考慮的是設(shè)定元素的 width/height 屬性,其次再考慮其他屬性。

    對(duì) IE6 及更早版本來說,常用的方法被稱為霍莉破解(Holly hack),即設(shè)定這個(gè)元素的高度為 1% (height:1%;)。需要注意的是,當(dāng)這個(gè)元素的 overflow 屬性被設(shè)置為 visible 時(shí),這個(gè)方法就失效了。或者使用 IE 的條件注釋。

    對(duì) IE7 來說,最好的方法時(shí)設(shè)置元素的最小高度為 0 (min-height:0;)。

    haslayout 問題引起的常見 bug
    IE6 及更低版本的雙空白邊浮動(dòng) bug
    bug 修復(fù): display:inline;

    IE5-6/win 的 3 像素偏移 bug
    bug 修復(fù): _height:1%;

    IE6 的躲躲貓(peek-a-boo) bug
    bug 修復(fù): _height:1%;

    這里列出觸發(fā) hasLayout 元素的一些效果

    1.阻止外邊距折疊

    兩個(gè)相連的 div 在垂直上的外邊距會(huì)發(fā)生疊加,而觸發(fā) hasLayout 的元素之間則不會(huì)有這種情況發(fā)生,如下圖:


    上圖的例子中,三個(gè) div 各包含一個(gè) p 元素,三個(gè) div 及其包含的 p 元素都有頂部和底部的外邊距,但只有第三個(gè) div 的邊距沒有與它的子元素 p 的外邊距折疊。這是因?yàn)榈谌齻€(gè) div 使用 zoom: 1 觸發(fā)了 hasLayout ,阻止了它與它的子元素的外邊距折疊。

    另外,例子中也使用了 overflow: hidden 觸發(fā)元素的 BFC ,這利用了 BFC 阻止外邊距折疊的特性達(dá)到元素在 IE 與現(xiàn)代瀏覽器下的表現(xiàn)統(tǒng)一。

    2.可以包含浮動(dòng)的子元素,即計(jì)算高度時(shí)包括其浮動(dòng)子元素

    效果如圖:


    上圖的例子中,有兩個(gè) div ,它們各包含一個(gè)設(shè)置了浮動(dòng)的 p 元素,但第一個(gè) div 實(shí)際被瀏覽器判斷為沒有高度和寬度,即高度為 0 ,上下邊框重疊在一起。而第二個(gè) div 使用 zoom: 1 觸發(fā)了 hasLayout ,可以包含浮動(dòng)元素,因此能正確表現(xiàn)出高度,其邊框位置也正常了。

    本例子中也使用了 overflow: hidden 觸發(fā) BFC ,跟上例相似,這利用了 BFC 可以包含浮動(dòng)子元素的特性達(dá)到元素在 IE 與現(xiàn)代瀏覽器下的表現(xiàn)統(tǒng)一。

    3.背景圖像顯示問題

    元素背景圖不能正確顯示是網(wǎng)頁代碼重構(gòu)中最常見的問題之一了,在 IE 7 及以下的 IE 版本中,沒有設(shè)置高度、寬度的元素往往不能顯示出背景圖(背景色則顯示正常),這實(shí)際上與 hasLayout 有關(guān)。實(shí)際的情況是,沒有觸發(fā) hasLayout 的元素不能顯示背景圖,上面有說過,觸發(fā) hasLayout 也就是使到元素?fù)碛胁季郑瑩Q句話說,擁有布局的元素才能正確顯示背景圖。如下圖:


    上圖兩個(gè) div 都設(shè)置了背景圖,但只有使用 zoom: 1 觸發(fā)了 hasLayout 的第二個(gè) div 才能正確顯示背景圖。

    本例子中沒有觸發(fā)元素的 BFC ,這是因?yàn)樵诂F(xiàn)代瀏覽器中,元素本身并沒有背景圖顯示問題。

    以上本文講述text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊 兼容IE,希望大家喜歡。

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊兼容IE_javascript技巧

    text-align:justify實(shí)現(xiàn)文本兩端對(duì)齊兼容IE_javascript技巧:對(duì)于text-align 我們?cè)偈煜げ贿^了,可是它有個(gè)justify屬性,平時(shí)很少用到,就鮮為人知了。justify是一種文本靠兩邊布局方式,一般應(yīng)用于書刊雜志排版;合理運(yùn)用text-align:justify 有時(shí)會(huì)省去很多開發(fā)的時(shí)間。 要想更好的理解 css, 尤其是 IE 下對(duì)
    推薦度:
    標(biāo)簽: 兩端對(duì)齊 IE 文本
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 国产精品香蕉在线观看| 999久久久免费精品国产| 在线观看亚洲精品国产| 欧美日韩精品一区二区在线播放| 中文字幕精品一区二区三区视频| 成人精品一区二区三区免费看 | 国产精品二区观看| 亚洲精品国产首次亮相| 国产高清精品在线| 国产精品成人观看视频国产| 亚洲精品永久在线观看| 国产精品无码一区二区在线| 国产精品一二三区| 精品无码人妻一区二区免费蜜桃| 欧美亚洲另类精品第一页| 1区1区3区4区产品芒果精品| 国产欧美精品AAAAAA片| 最新精品亚洲成a人在线观看| 国产精品爽爽ⅴa在线观看| 国产99精品久久| 精品深夜AV无码一区二区| 亚洲无码日韩精品第一页| 精品偷自拍另类在线观看丰满白嫩大屁股ass | 国产AV午夜精品一区二区三区 | 国产精品视频免费一区二区| 99久久久精品| 国内精品九九久久久精品| 最新国产精品精品视频| 久久精品免费网站网| 国产精品久久久久乳精品爆| 国产精品久久毛片完整版| 久久国产免费观看精品3| 正在播放国产精品每日更新| 久久久久亚洲精品中文字幕 | 成人国内精品久久久久一区 | 青青草国产精品久久| 欧美激情视频精品一区二区| 办公室久久精品| 国产精品黄网站| 国产精品免费无遮挡无码永久视频 | www.99精品|