掌握盒模型輕松DIV CSS網(wǎng)頁布局
互聯(lián)網(wǎng) 發(fā)布時間:2009-04-02 19:37:16 作者:佚名
我要評論

網(wǎng)頁制作Webjx文章簡介:如果想熟練掌握DIV和CSS的布局方法,首先要對盒模型有足夠的了解。每個HTML元素都可以看作一個裝了東西的盒子,盒子里面的內(nèi)容到盒子的邊框之間的距離即填充padding,盒子本身有邊框border,而盒子邊框外和其他盒子之間
如果想熟練掌握DIV和CSS的布局方法,首先要對盒模型有足夠的了解。每個HTML元素都可以看作一個裝了東西的盒子,盒子里面的內(nèi)容到盒子的邊框之間的距離即填充padding,盒子本身有邊框border,而盒子邊框外和其他盒子之間,還有邊界margin.
如果想熟練掌握DIV和CSS的布局方法,首先要對盒模型有足夠的了解。每個HTML元素都可以看作一個裝了東西的盒子,盒子里面的內(nèi)容到盒子的邊框之間的距離即填充(padding),盒子本身有邊框(border),而盒子邊框外和其他盒子之間,還有邊界(margin),如圖1所示。

圖1 盒模型圖解
填充、邊框和邊界都分為“上右下左”四個方向,既可以分別定義,也可以統(tǒng)一定義。
CSS內(nèi)定義的寬(width)和高(height),指的是填充以內(nèi)的內(nèi)容范圍,因此一個元素:
實(shí)際寬度 = 左邊界 左邊框 左填充 內(nèi)容寬度(width) 右填充 右邊框 右邊界
實(shí)際高度 = 上邊界 上邊框 上填充 內(nèi)容高度(height) 下填充 下邊框 下邊界
例如有CSS定義如下:
#menu { background: #9cf; margin: 20px; border: 10px solid #039; padding: 40px; width: 200px; }
則其實(shí)際寬度如圖2所示。

圖2 元素總寬度的計(jì)算
而對于Windows IE 5.x及更前的版本,把這個盒模型的定義搞錯了,它認(rèn)為:
寬度(width)= 元素內(nèi)容 填充 邊框
這個確實(shí)很容易搞錯,很多對于盒模型定義沒有深入了解的人也同樣容易犯這個錯誤。例如:
#menu { width: 200px; padding: 5px; border: 1px solid #ccc; }
那么,在IE5.5中div實(shí)際內(nèi)容的寬度將是200px-5px-1px-5px-1px=188px,而在Firefox、Opera及IE 6等瀏覽器內(nèi)寬度則是200px。
這正是很多新手發(fā)現(xiàn)自己定義的頁面在不同的瀏覽器內(nèi)看會發(fā)生錯位的原因之一。
因此就需要采取一定的彌補(bǔ)措施,一般可以避免同時定義元素的寬度和填充、邊框,而將一些定義放到元素的子元素內(nèi)定義。
如果必須同時定義這幾個值,也可以使用一些手段來校正這個錯誤,即俗稱的css hack,其基本思想就是為沒有錯誤的瀏覽器提供一個正確的寬度值,而對IE5.5等有問題的瀏覽器提供另一個值。
例如如下的寫法:
#menu { padding: 5px; width:110px; voice-family: ""}""; voice-family: inherit; width: 100px; }
定義中第一個width:110px,是IE 5.5認(rèn)為的元素的寬度,100px 5px 5px。 voice-family: “”}”";
voice-family: inherit;
是CSS2.0中的語音屬性,由于Windows IE5.5不完全支持CSS2.0,不識別此屬性,因此跳到下一個選擇符。但是其他瀏覽器(包括IE6)會繼續(xù)解讀下面的定義,由于css是“層疊”的,即對于同一個選擇符的相同的屬性,后面的定義會覆蓋掉前面的定義,因此,對于其他的瀏覽器,#menu的寬度為最后的100px。
另一個常用的hack手法是使用!important(聲明),聲明加在CSS屬性定義的后面,此條屬性的級別將變成最高,即使后面有相同的定義也不會覆蓋掉聲明過的定義,不過IE不支持!important。
例如有如下css定義:
#box { border: 1px solid #B51C8C; width:768px; }
而其修正方法如圖3所示。

圖3 針對IE修正CSS
對于支持!important的瀏覽器,將接受width:768px,而ie6雖然不支持!important,但是由于其無法解釋“ /**/(空注釋)”,因此會忽略后面的定義,而ie 5.5卻會接受最后定義的width:770px,因此達(dá)到修正的目的。
關(guān)于盒模型,還有以下幾點(diǎn)需要注意:
・對于塊級元素(display:block),未浮動的垂直相鄰元素的上邊界和下邊界會被壓縮,例如:有上下2個元素,上元素的下邊界為5px,下面元素的上邊界為20px,則實(shí)際2個元素的間距為20px(2個邊界值中較大的值)。如圖4所示。

圖4 邊界的壓縮 注1. 塊級元素(display: block)
每個塊級元素都從一個新行開始,而且其后的元素也需另起一行開始,標(biāo)題、段落、表格、層、body等都是塊級元素。塊級元素只能作為其他塊級元素的子元素,而且需要一定的條件。
・內(nèi)聯(lián)元素,例如<a>、<span>等,定義上下邊界不會影響到行高(line-height),內(nèi)聯(lián)元素距離上一行元素的距離由行高決定,而不是填充或邊界。 注2. 內(nèi)聯(lián)元素(display: inline)
內(nèi)聯(lián)元素不需要在新行內(nèi)顯示,而且也不強(qiáng)迫其后的元素?fù)Q行,如a、em、span等都為內(nèi)聯(lián)元素。內(nèi)聯(lián)元素可以為任何其他元素的子元素。
・浮動元素(無論左或者右浮動)邊界不壓縮,且若浮動元素不聲明寬度,則其寬度趨向于0,即壓縮到其內(nèi)容能承受的最小寬度。
・如果盒中沒有內(nèi)容,則即使定義了寬度和高度都為100%,實(shí)際上只占0%,因此不會被顯示,此點(diǎn)在采取層布局的時候需特別注意。
・邊界值可為負(fù),其顯示效果各瀏覽器可能不相同。
・填充值不可為負(fù)。
・邊框默認(rèn)的樣式(border-style)為不顯示(none)。
相關(guān)文章
解析CSS的box model盒模型及其內(nèi)的子元素布局控制
盒模型是CSS控制布局的主要方式之一,尤其是內(nèi)部的元素排列控制,這里我們將來解析CSS的box model盒模型及其內(nèi)的子元素布局控制,需要的朋友可以參考下2016-07-01- 下面小編就為大家?guī)硪黄狢SS3彈性盒模型flex box快速入門心得(必看篇)。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-24
- 下面小編就為大家?guī)硪黄狢SS彈性盒模型flex在布局中的應(yīng)用詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-24
- 這篇文章主要介紹了幾個CSS3的flex彈性盒模型布局的簡單例子演示,flex布局是迄今為止最強(qiáng)大的web布局方式,需要的朋友可以參考下2016-05-12
CSS網(wǎng)頁布局的核心內(nèi)容:CSS盒模型
網(wǎng)頁制作Webjx文章簡介:本節(jié)的內(nèi)容非常重要,因?yàn)楹心P褪荂SS定位布局的核心內(nèi)容。從前面章節(jié)中,讀者學(xué)習(xí)了布局網(wǎng)頁基本方法,只需利用p元素和列表元素,即可完成頁面大2009-04-02- 下面小編就為大家?guī)硪黄猚ss布局模型全面了解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-19