• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    CSShaslayout徹底了解

    來源:懂視網 責編:小采 時間:2020-11-27 18:50:53
    文檔

    CSShaslayout徹底了解

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

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

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

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    CSShaslayout徹底了解

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 国产办公室秘书无码精品99| 久久99精品综合国产首页| 99久久99久久精品免费看蜜桃| 精品国产一级在线观看 | 正在播放国产精品每日更新| 柠檬福利精品视频导航| 久久精品国产亚洲av麻豆小说 | 精品视频在线v| 日韩精品乱码AV一区二区| 久久丝袜精品中文字幕| 91精品无码久久久久久五月天| 国产精品久久午夜夜伦鲁鲁| 亚洲精品V欧洲精品V日韩精品 | 91视频国产精品| 精品一区二区三区在线观看视频 | 九九热在线精品视频| 精品人妻无码一区二区色欲产成人| 日韩美女18网站久久精品| 精品视频一区二区三区四区五区| 精品国产美女福利到在线不卡| 国产精品一区二区久久不卡 | 国产精品扒开腿做爽爽爽视频| 一夲道无码人妻精品一区二区| 久久久久国产成人精品亚洲午夜| 国产成人综合久久精品尤物| 四虎影视884a精品国产四虎| 精品四虎免费观看国产高清午夜| 国产精品多人p群无码| 国自产偷精品不卡在线| 久久精品一本到99热免费| 日韩av无码久久精品免费| 亚洲精品无码午夜福利中文字幕| 亚洲精品动漫免费二区| 日韩欧美亚洲国产精品字幕久久久| 久久精品国产清自在天天线| 精品一区二区三区高清免费观看| 国产偷伦精品视频| 九色精品视频在线观看| 欧美精品高清在线xxxx| 亚洲综合欧美精品一区二区| 日韩精品国产另类专区|