• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuā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)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
    問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
    當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

    CSShaslayout徹底了解

    來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 18:50:53
    文檔

    CSShaslayout徹底了解

    CSShaslayout徹底了解:要想更好的理解 css, 尤其是 IE 下對(duì) css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清除的概念。大多IE下的顯示錯(cuò)誤,就是源于 haslayout。什么是 haslayout ? haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在I
    推薦度:
    導(dǎo)讀CSShaslayout徹底了解:要想更好的理解 css, 尤其是 IE 下對(duì) css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清除的概念。大多IE下的顯示錯(cuò)誤,就是源于 haslayout。什么是 haslayout ? haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在I

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

    什么是 haslayout ?
      haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在InternetExplorer中,一個(gè)元素要么自己對(duì)自身的內(nèi)容進(jìn)行計(jì)算大小和組織,要么依賴(lài)于父元素來(lái)計(jì)算尺寸和組織內(nèi)容。為了調(diào)節(jié)這兩個(gè)不同的概念,渲染引擎采用了 hasLayout 的屬性,屬性值可以為true或false。當(dāng)一個(gè)元素的 hasLayout屬性值為true時(shí),我們說(shuō)這個(gè)元素有一個(gè)布局(layout)
      當(dāng)一個(gè)元素有一個(gè)布局時(shí),它負(fù)責(zé)對(duì)自己和可能的子孫元素進(jìn)行尺寸計(jì)算和定位。簡(jiǎn)單來(lái)說(shuō),這意味著這個(gè)元素需要花更多的代價(jià)來(lái)維護(hù)自身和里面的內(nèi)容,而不是依賴(lài)于祖先元素來(lái)完成這些工作。因此,一些元素默認(rèn)會(huì)有一個(gè)布局。當(dāng)我們說(shuō)一個(gè)元素“擁有l(wèi)ayout”或“得到layout”,或者說(shuō)一個(gè)元素“has layout” 的時(shí)候,我們的意思是指它的微軟專(zhuān)有屬性 hasLayout 被設(shè)為了 true。一個(gè)“l(fā)ayout元素”可以是一個(gè)默認(rèn)就擁有 layout 的元素或者是一個(gè)通過(guò)設(shè)置某些 CSS 屬性得到 layout的元素。如果某個(gè)HTML元素?fù)碛?haslayout 屬性,那么這個(gè)元素的 haslayout 的值一定只有 true,haslayout為只讀屬性 一旦被觸發(fā),就不可逆轉(zhuǎn)。通過(guò) IE Developer Toolbar 可以查看 IE 下 HTML元素是否擁有haslayout,在 IE Developer Toolbar 下,擁有 haslayout的元素,通常顯示為“haslayout = -1”。
      負(fù)責(zé)組織自身內(nèi)容的元素將默認(rèn)有一個(gè)布局,主要包括以下元素(不完全列表):
      * body and html
      * table, tr, th, td
      * img
      * hr
      * input, button, file, select, textarea, fieldset
      * marquee
      * frameset, frame, iframe
      * objects, applets, embed
      對(duì)于并非所有的元素都默認(rèn)有布局,微軟給出的主要原因是“性能和簡(jiǎn)潔”。如果所有的元素都默認(rèn)有布局,會(huì)對(duì)性能和內(nèi)存使用上產(chǎn)生有害的影響。
      如何激發(fā) haslayout?
      大部分的 IE 顯示錯(cuò)誤,都可以通過(guò)激發(fā)元素的 haslayout 屬性來(lái)修正。可以通過(guò)設(shè)置 css 尺寸屬性(width/height)等來(lái)激發(fā)元素的 haslayout,使其“擁有布局”。如下所示,通過(guò)設(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 中不支持。
      具有“l(fā)ayout” 的元素如果同時(shí) display: inline ,那么它的行為就和標(biāo)準(zhǔn)中所說(shuō)的 inline-block很類(lèi)似了:在段落中和普通文字一樣在水平方向和連續(xù)排列,受 vertical-align影響,并且大小可以根據(jù)內(nèi)容自適應(yīng)調(diào)整。這也可以解釋為什么單單在 IE/Win 中內(nèi)聯(lián)元素可以包含塊級(jí)元素而少出問(wèn)題,因?yàn)樵趧e的瀏覽器中display: inline 就是內(nèi)聯(lián),不像 IE/Win 一旦內(nèi)聯(lián)元素?fù)碛?layout 還會(huì)變成 inline-block。
      haslayout 問(wèn)題的調(diào)試與解決
      當(dāng)網(wǎng)頁(yè)在 IE 中有異常表現(xiàn)時(shí),可以嘗試激發(fā) haslayout 來(lái)看看是不是問(wèn)題所在。常用的方法是給某元素 css 設(shè)定 zoom:1。使用 zoom:1 是因?yàn)榇蠖鄶?shù)情況下,它能在不影響現(xiàn)有環(huán)境的條件下激發(fā)元素的 haslayout。而一旦問(wèn)題消失,那基本上就可以判斷是haslayout 的原因。然后就可以通過(guò)設(shè)定相應(yīng)的 css 屬性來(lái)對(duì)這個(gè)問(wèn)題進(jìn)行修正了。建議首先要考慮的是設(shè)定元素的width/height 屬性,其次再考慮其他屬性。
      對(duì) IE6 及更早版本來(lái)說(shuō),常用的方法被稱(chēng)為霍莉破解(Holly hack),即設(shè)定這個(gè)元素的高度為 1%(height:1%;)。需要注意的是,當(dāng)這個(gè)元素的 overflow 屬性被設(shè)置為 visible 時(shí),這個(gè)方法就失效了。或者使用 IE的條件注釋。
      對(duì) IE7 來(lái)說(shuō),最好的方法時(shí)設(shè)置元素的最小高度為 0 (min-height:0;)。
      haslayout 問(wèn)題引起的常見(jiàn) bug
      IE6 及更低版本的雙空白邊浮動(dòng) bug
      bug 修復(fù): display:inline;
      IE5-6/win 的 3 像素偏移 bug
      bug 修復(fù): _height:1%;
      E6 的躲躲貓(peek-a-boo) bug
      bug 修復(fù): _height:1%;

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

    文檔

    CSShaslayout徹底了解

    CSShaslayout徹底了解:要想更好的理解 css, 尤其是 IE 下對(duì) css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清除的概念。大多IE下的顯示錯(cuò)誤,就是源于 haslayout。什么是 haslayout ? haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在I
    推薦度:
    標(biāo)簽: 徹底 ha 理解
    • 熱門(mén)焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門(mén)推薦

    專(zhuān)題
    Top
    主站蜘蛛池模板: 日韩三级精品| 国产午夜精品一区二区三区| 久久精品人人槡人妻人人玩AV| 99热精品毛片全部国产无缓冲| 人妻熟妇乱又伦精品视频 | 亚洲2022国产成人精品无码区| 国产精品亚洲二区在线观看| 国产精品1024香蕉在线观看| 亚洲国产精品福利片在线观看| 久久精品中文字幕第23页| 99久久国产主播综合精品| 91在线视频精品| 久久精品国产亚洲av水果派| 亚洲国产精品第一区二区三区| 国语自产精品视频| 成人精品一区二区三区电影黑人| 国产精品久久久久久久久免费| 久久精品aⅴ无码中文字字幕重口| 亚洲精品成人久久久| 久久99精品久久久久久9蜜桃| 国产A级毛片久久久精品毛片| 精品视频在线v| 久久91精品久久91综合| 国产成人精品日本亚洲18图| 成人伊人精品色XXXX视频| 久久精品人人做人人爽97| 久久精品国产第一区二区三区| 无码精品国产VA在线观看DVD | 99久久er这里只有精品18| 精品国产第一国产综合精品| 少妇人妻精品一区二区三区| 最新精品露脸国产在线| 久久se精品一区二区影院| 久久精品无码专区免费| 精品亚洲成α人无码成α在线观看| 九九久久精品无码专区| 欧美精品亚洲精品日韩精品| 日韩三级精品| 无码人妻精品一区二区| 久久水蜜桃亚洲av无码精品麻豆| 欧美精品亚洲精品日韩传电影|