網站首頁 網站建設 公司動態 行業新聞 案例展示 關于我們

文章內容

【轉載】haslayout綜合

日期:2013-11-29  來源:攀枝花惠康網絡公司

Internet Explorer 7 還有一些額外的屬性(不完全列表):

原文地址:http://www.qianduan.net/comprehensive-haslayout.html

要想更好的理解 css, 尤其是 IE 下對 css 的襯著,haslayout 是一個很是有需要徹底弄斷根的概念。年夜多 IE
下的顯示錯誤,就是閱暌冠 haslayout。

什么是 haslayout ?

當一個元素有一個結構時,它負責對自己和可能的子孫元素進行尺寸計較和定位。簡單來說,這意味著這個元素需要花更多的價錢來維護自身和瑯縵沔的內容,而不是依靠于祖先元素來完成這些工作。是以,一些元素默認會有一個結構。當我們說一個元素“擁有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”。

bug 修復: _height:1%;

負責組織自身內容的元素將默認有一個結構,首要搜羅以下元素(不完全列表):

糖伴西紅柿說,這篇文章不是原創,是網上資本的匯總,加上自己理解的綜合??赡苓€不是很周全,還需要再進一步細化。

* body and html
* table, tr, th, td
* objects, applets, embed


* img
* input, button, file, select, textarea, fieldset
* marquee
* frameset, frame, iframe

年夜部門的 IE 顯示錯誤,都可以經由過程激發元素的 haslayout 屬性來批改??梢越浻蛇^程設置 css 尺寸屬性(width/height)等來激發元素的 haslayout,使其“擁有結構”。如下所示,經由過程設置以下 css 屬性即可。

* display: inline-block
* height: (任何值除了auto)
* position: absolute

對于并非所有的元素都默認有結構,微軟給出的首要原因是“機能和精練”。如不美觀所有的元素都默認有結構,會對機能和內存使用上發生有害的影響。

若何激發 haslayout?


* float: (left 或 right)
* hr
* width: (任何值除了auto)
* writing-mode: tb-rl
* zoom: (除 normal 外肆意值)

* 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 問題的調試與解決

haslayout 是Windows Internet Explorer襯著引擎的一個內部組成部門。在Internet Explorer中,一個元素要么自己對自身的內容進行計較巨細和組織,要么依靠于父元素來計較尺寸和組織內容。為了調節這兩個分歧的概念,襯著引擎采用了 hasLayout 的屬性,屬性值可覺得true或false。當一個元素的 hasLayout 屬性值為true時,我們嗣魅這個元素有一個結構(layout)

當網頁在 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

文章來源:攀枝花惠康網絡公司

惠康網絡,是一家專業從事攀枝花網站建設,攀枝花網站制作,攀枝花網站設計公司,提供網站建設一條龍服務(網站域名注冊+網站服務器租用+網站開發+網站維護+網站營銷推廣),惠康網絡立足攀枝花,輻射全中國,攀枝花惠康網絡的客戶已經遍布國內各地大中小城市,我們高效優質的網站建設服務深受用戶好評。

客服熱線:tel(謝先生)  客服QQ:1323605005  
服務郵箱:[email protected](售前咨詢)  [email protected](技術部)  [email protected](售后服務)
公司地址:四川省攀枝花市
郵編:617200

青海十一选五开奖图