1. 程式人生 > >CSS 布局模型

CSS 布局模型

-- head style max 生成 borde 能夠 cor 文本文

css布局模型



布局模型與盒模型一樣都是 CSS 最基本、 最核心的概念。

但布局模型是建立在盒模型基礎之上。又不同於我們常說的 CSS 布局樣式或 CSS 布局模板。假設說布局模型是本。那麽 CSS 布局模板就是末了。是外在的表現形式。


CSS包括3種主要的布局模型。用英文概括為:Flow、Layer 和 Float。


在網頁中。元素有三種布局模型:
1、流動模型(Flow)
2、浮動模型 (Float)
3、層模型(Layer)

流動模型

先來說一說流動模型,流動(Flow)是默認的網頁布局模式。也就是說網頁在默認狀態下的 HTML 網頁元素都是依據流動模型來分布網頁內容的。

流動布局模型具有2個比較典型的特征:

第一點。塊狀元素都會在所處的包括元素內自上而下按順序垂直延伸分布,由於在默認狀態下,塊狀元素的寬度都為100%。實際上。塊狀元素都會以行的形式占領位置。如右側代碼編輯器中三個塊狀元素標簽(div,h1,p)寬度顯示為100%。

第二點,在流動模型下。內聯元素都會在所處的包括元素內從左到右水平分布顯示。(內聯元素可不像塊狀元素這麽霸道獨占一行)

浮動模型

塊狀元素這麽霸道都是獨占一行,假設如今我們想讓兩個塊狀元素並排顯示,怎麽辦呢?不要著急,設置元素浮動就能夠實現這一願望。

不論什麽元素在默認情況下是不能浮動的,但能夠用 CSS 定義為浮動,如 div、p、table、img 等元素都能夠被定義為浮動。

例如以下代碼能夠實現兩個 div 元素一行顯示。

div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:left;
}
<div id="div1"></div>
<div id="div2"></div>

效果圖

技術分享

當然你也能夠同一時候設置兩個元素右浮動也能夠實現一行顯示。

div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:right;
}

效果圖

技術分享

又有小夥伴問了。設置兩個元素一左一右能夠實現一行顯示嗎?當然能夠:

div{
    width:200px;
    height:200px;
    border:2px red solid;
}
#div1{float:left;}
#div2{float:right;}

效果圖

技術分享


什麽是層模型?

什麽是層布局模型?層布局模型就像是圖像軟件PhotoShop中很流行的圖層編輯功能一樣。每一個圖層可以精確定位操作,但在網頁設計領域,因為網頁大小的活動性。層布局沒能受到熱捧。

可是在網頁上局部使用層布局還是有其方便之處的。以下我們來學習一下html中的層布局。

怎樣讓html元素在網頁中精確定位,就像圖像軟件PhotoShop中的圖層一樣可以對每一個圖層可以精確定位操作。CSS定義了一組定位(positioning)屬性來支持層布局模型。

層模型有三種形式:

1、絕對定位(position: absolute)

2、相對定位(position: relative)

3、固定定位(position: fixed)

層模型--絕對定位

假設想為元素設置層模型中的絕對定位,須要設置position:absolute(表示絕對定位),這條語句的作用將元素從文檔流中拖出來,然後使用left、right、top、bottom屬性相對於其最接近的一個具有定位屬性的父包括塊進行絕對定位。假設不存在這種包括塊,則相對於body元素,即相對於瀏覽器窗體

如以下代碼能夠實現div元素相對於瀏覽器窗體向右移動100px,向下移動50px。

div{
    width:200px;
    height:200px;
    border:2px red solid;
    position:absolute;
    left:100px;
    top:50px;
}
<div id="div1"></div>

效果例如以下:

技術分享


層模型--相對定位

假設想為元素設置層模型中的相對定位,須要設置position:relative(表示相對定位),它通過left、right、top、bottom屬性確定元素在正常文檔流中的偏移位置。相對定位完畢的過程是首先按static(float)方式生成一個元素(而且元素像層一樣浮動了起來)。然後相對於曾經的位置移動,移動的方向和幅度由left、right、top、bottom屬性確定,偏移前的位置保留不動

例如以下代碼實現相對於曾經位置向下移動50px。向右移動100px;

#div1{
    width:200px;
    height:200px;
    border:2px red solid;
    position:relative;
    left:100px;
    top:50px;
}

<div id="div1"></div>


效果圖:

技術分享

什麽叫做“偏移前的位置保留不動”呢?

大家能夠做一個實驗。在代碼編輯器div標簽的後面增加一個span標簽,在標並在span標簽中寫入一些文字。例如以下代碼:

<body>
    <div id="div1"></div><span>偏移前的位置還保留不動,覆蓋不了前面的div沒有偏移前的位置</span>
</body>

效果圖:

技術分享

從效果圖中能夠明顯的看出。盡管div元素相對於曾經的位置產生了偏移。可是div元素曾經的位置還是保留著,所以後面的span元素是顯示在了div元素曾經位置的後面。

層模型--固定定位

fixed:表示固定定位,與absolute定位類型類似,但它的相對移動的坐標是視圖(屏幕內的網頁窗體)本身。因為視圖本身是固定的。它不會隨瀏覽器窗體的滾動欄滾動而變化,除非你在屏幕中移動瀏覽器窗體的屏幕位置,或改變瀏覽器窗體的顯示大小,因此固定定位的元素會始終位於瀏覽器窗體內視圖的某個位置,不會受文檔流動影響,這與background-attachment:fixed?屬性功能同樣。下面代碼能夠實現相對於瀏覽器視圖向右移動100px,向下移動50px。而且拖動滾動欄時位置固定不變。

#div1{
    width:200px;
    height:200px;
    border:2px red solid;
    position:fixed;
    left:100px;
    top:50px;
}
<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本。

</p> ....


Relative與Absolute組合使用

小夥伴們學習了12-6小節的絕對定位的方法:使用position:absolute能夠實現被設置元素相對於瀏覽器(body)設置定位以後。大家有沒有想過可不能夠相對於其他元素進行定位呢?答案是肯定的。當然能夠。

使用position:relative來幫忙,可是必須遵守以下規範:

1、參照定位的元素必須是相對定位元素的前輩元素:

<div id="box1"><!--參照定位的元素-->
    <div id="box2">相對參照元素進行定位</div><!--相對定位元素-->
</div>

從上面代碼能夠看出box1是box2的父元素(父元素當然也是前輩元素了)。

2、參照定位的元素必須增加position:relative;

#box1{
    width:200px;
    height:200px;
    position:relative;        
}

3、定位元素增加position:absolute,便能夠使用top、bottom、left、right來進行偏移定位了。

#box2{
    position:absolute;
    top:20px;
    left:30px;         
}

這樣box2就能夠相對於父元素box1定位了(這裏註意參照物就能夠不是瀏覽器了,而能夠自由設置了)。





CSS 布局模型