當前位置:才華齋>設計>網頁設計>

CSS教程之盒模型

網頁設計 閱讀(3.18W)

如果想熟練掌握DIV和CSS的佈局方法,首先要對盒模型有足夠的瞭解。每個HTML元素都可以看作一個裝了東西的盒子,盒子裡面的內容到盒子的邊框之間的距離即填充(padding),盒子本身有邊框(border),而盒子邊框外和其他盒子之間,還有邊界(margin)

CSS教程之盒模型

  1.盒模型

填充、邊框和邊界都分為“上右下左”四個方向,既可以分別定義,也可以統一定義。

CSS內定義的寬(width)和高(height),指的是填充以內的內容範圍,因此一個元素:

實際寬度=左邊界 左邊框 左填充 內容寬度(width) 右填充 右邊框 右邊界

實際高度=上邊界 上邊框 上填充 內容高度(height) 下填充 下邊框 下邊界

例如有CSS定義如下:

#menu{

background:#9cf;

margin:20px;

border:10pxsolid#039;

padding:40px;

width:200px;

}

  2.元素總寬度的計算

而對於WindowsIE5.x及更前的版本,把這個盒模型的定義搞錯了,它認為:

寬度(width)=元素內容 填充 邊框

這個確實很容易搞錯,很多對於盒模型定義沒有深入瞭解的人也同樣容易犯這個錯誤。

例如:

#menu{

width:200px;

padding:5px;

border:1pxsolid#ccc;

}

那麼,在IE5.5中div實際內容的寬度將是200px-5px-1px-5px-1px=188px,而在Firefox、Opera及IE6等瀏覽器內寬度則是200px。

這正是很多新手發現自己定義的頁面在不同的瀏覽器內看會發生錯位的原因之一。

因此就需要採取一定的彌補措施,一般可以避免同時定義元素的寬度和填充、邊框,而將一些定義放到元素的子元素內定義。

如果必須同時定義這幾個值,也可以使用一些手段來校正這個錯誤,即俗稱的csshack,其基本思想就是為沒有錯誤的瀏覽器提供一個正確的寬度值,而對IE5.5等有問題的瀏覽器提供另一個值。

例如如下的寫法:

#menu{

padding:5px;

width:110px;

voice-family:""}"";

voice-family:inherit;

width:100px;

}

定義中第一個width:110px,是IE5.5認為的元素的寬度,100px 5px 5px。

voice-family:""}"";

voice-family:inherit;

是CSS2.0中的語音屬性,由於WindowsIE5.5不完全支援CSS2.0,不識別此屬性,因此跳到下一個選擇符。但是其他瀏覽器(包括IE6)會繼續解讀下面的定義,由於css是“層疊”的,即對於同一個選擇符的'相同的屬性,後面的定義會覆蓋掉前面的定義,因此,對於其他的瀏覽器,#menu的寬度為最後的100px。

另一個常用的hack手法是使用!important(宣告),宣告加在CSS屬性定義的後面,此條屬性的級別將變成最高,即使後面有相同的定義也不會覆蓋掉宣告過的定義,不過IE不支援!important。

例如有如下css定義:

#box{

border:1pxsolid#B51C8C;

width:768px;

}

  3.針對IE修正CSS

對於支援!important的瀏覽器,將接受width:768px,而ie6雖然不支援!important,但是由於其無法解釋“/**/(空註釋)”,因此會忽略後面的定義,而ie5.5卻會接受最後定義的width:770px,因此達到修正的目的。

關於盒模型,還有以下幾點需要注意:

·對於塊級元素(display:block),未浮動的垂直相鄰元素的上邊界和下邊界會被壓縮,例如:有上下2個元素,上元素的下邊界為5px,下面元素的上邊界為20px,則實際2個元素的間距為20px(2個邊界值中較大的值)。

邊界的壓縮

注1.塊級元素(display:block)

每個塊級元素都從一個新行開始,而且其後的元素也需另起一行開始,標題、段落、表格、層、body等都是塊級元素。塊級元素只能作為其他塊級元素的子元素,而且需要一定的條件。

·內聯元素,例如、等,定義上下邊界不會影響到行高(line-height),內聯元素距離上一行元素的距離由行高決定,而不是填充或邊界。

注2.內聯元素(display:inline)

內聯元素不需要在新行內顯示,而且也不強迫其後的元素換行,如a、em、span等都為內聯元素。內聯元素可以為任何其他元素的子元素。

·浮動元素(無論左或者右浮動)邊界不壓縮,且若浮動元素不宣告寬度,則其寬度趨向於0,即壓縮到其內容能承受的最小寬度。

·如果盒中沒有內容,則即使定義了寬度和高度都為100%,實際上只佔0%,因此不會被顯示,此點在採取層佈局的時候需特別注意。

·邊界值可為負,其顯示效果各瀏覽器可能不相同。

·填充值不可為負。

·邊框預設的樣式(border-style)為不顯示(none)。