CSS佈局模型/網頁佈局基礎

CSS佈局模型


清楚了CSS 盒模型的基本概念、 盒模型類型, 我們就可以深入探討網頁佈局的基本模型了。佈局模型與盒模型一樣都是 CSS 最基本、 最核心的概念。 但佈局模型是建立在盒模型基礎之上,又不同於我們常說的 CSS 佈局樣式或 CSS 佈局模板。如果說佈局模型是本,那麼 CSS 佈局模板就是末了,是外在的表現形式。

CSS包含3種基本的佈局模型,用英文概括爲:Flow、Layer 和 Float。

在網頁中,元素有三種佈局模型:

  1. 流動模型(Flow)

  2. 浮動模型 (Float)

  3. 層模型(Layer)

在網頁中,元素有三種定位機制:

  1. 標準文檔流(Normal flow)

  2. 浮動(Floats)

  3. 絕對定位(Absolute)

標準文檔流(Normal flow)特點:

從上到下, 從左到右邊,輸出文檔內容。 由塊級元素和行級元素組成。

這三個佈局模型究竟是什麼佈局?下面會詳細給大家介紹。


流動模型 (一)


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

流動佈局模型具有2個比較典型的特徵:

第一點,塊狀元素 都會在所處的 包含元素 內自上而下按順序垂直延伸分佈,因爲在默認狀態下,塊狀元素的寬度都爲100%。實際上,塊狀元素都會以行的形式佔據位置。如示例代碼中三個塊狀元素標籤(div,h1,p)寬度顯示爲100%。

示例

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>流動模式下的塊狀元素</title>
<style type="text/css">
#box1{
    width:300px;
    height:100px;
}
div,h1,p{
    border:1px solid red;
}
</style>
</head>
<body>
    <div id="box2">box2</div><!--塊狀元素,由於沒有設置寬度,寬度默認顯示爲100%--> 
    <h1>標題</h1><!--塊狀元素,由於沒有設置寬度,寬度默認顯示爲100%--> 
    <p>文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段。</p><!--塊狀元素,由於沒有設置寬度,寬度默認顯示爲100%--> 

    <div id="box1">box1</div><!--塊狀元素,由於設置了width:300px,寬度顯示爲300px-->
</body>
</html>

這裏寫圖片描述


流動模型(二)


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

示例代碼中內聯元素標籤a、span、em、strong都是內聯元素。

示例

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>流動模式下的內聯元素</title>
<style type="text/css">
</style>
</head>
<body>
    <a href="http://blog.csdn.net/blog751196085">http://blog.csdn.net/blog751196085</a><span>強調</span><em>重點</em>
    <strong>強調</strong>
</body>
</html>

浮動模型(float屬性)


塊狀元素這麼霸道都是獨佔一行,如果現在我們想讓兩個塊狀元素並排顯示,怎麼辦呢?不要着急,設置元素浮動就可以實現這一願望。

任何元素在默認情況下是不能浮動的,但可以用 CSS 定義爲浮動,如 div、p、table、img 等元素都可以被定義爲浮動。如下代碼可以實現兩個 div 元素一行顯示。

div{
    width:200px;
    height:200px;
    border:2px red solid;
    float:left;/*從左邊浮動*/
    float:right; /*從右邊浮動*/
}
<div id="div1"></div>
<div id="div2"></div>

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

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

示例

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>浮動模型</title>
<style type="text/css">
div{
    border:2px red solid;
    width:100px;
    height:100px;
    float:left;
}
#div1{
    margin-right:10px;
}
</style>
</head>
<body>
<div id="div1">欄目1</div>
<div id="div2">欄目2</div>
</body>
</html>

這裏寫圖片描述

浮動_橫向兩列布局

  1. float屬性 —— 使縱向排列的塊級元素,橫向排列

  2. margin屬性 —— 設置兩列之間的間距

float 三個屬性值

  1. left – 左浮動

  2. right – 右浮動

  3. none – 不浮動

特點:元素會左移,或右移, 直到碰到容器爲止。

當元素設有置寬度值,而設置了浮動屬性, 元素的寬度隨內容的變化而變化

當元素設置了浮動屬性後, 仍舊處於標準文檔流中, 會對相鄰的元素產生影響(會對周圍的元素產生影響), 相鄰元素特指 緊鄰後面的元素

這裏寫圖片描述

清除浮動的常用方法

第一種:Clear 屬性 – 常用

  1. clear:both;

  2. clear:left

  3. clear:right

    當父包含快縮成一條線時,用 clear:both 方法清除浮動無效,它一般用於緊鄰後面的元素的清除浮動。

第二種

同時設置width:100%(或者固定寬度) + overflow:hidden(移除屬性);


什麼是層模型(positioning)?


什麼是層佈局模型?層佈局模型就像是圖像軟件PhotoShop中非常流行的圖層編輯功能一樣,每個圖層能夠精確定位操作,但在網頁設計領域,由於網頁大小的活動性,層佈局沒能受到熱捧。但是在網頁上局部使用層佈局還是有其方便之處的。下面我們來學習一下html中的層佈局。

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

層模型有三種形式:

1、絕對定位(position: absolute)

2、相對定位(position: relative)

3、固定定位(position: fixed) (屬於絕對定位)

4、靜態定位(position: static)


層模型 – – 絕對定位


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

建立了以包含塊爲基準的定位

完全脫離了標準文檔流(對其兄弟元素不在造成任何影響)

隨即擁有偏移屬性和z-index屬性

1、未設置偏移量

無論是否存在已定祖先元素,都保持初始位置。

脫離了標準文檔流

2、設置偏移量

偏移參照基準:

無已定位祖先元素,以<html>爲偏移參照基準

有已定位祖先元素,以距其最近的定位祖先元素爲偏移參照基準

當一個元素設置絕對定位, 沒有設置寬度時,元素的寬度根據內容進行調節。

橫向兩列布局

使用絕對定位實現橫向兩列布局, 應用比較少。

—–>常用於一列固定寬,另一列寬度自適應的情況

主要應用技能:

—–>relative—父元素相對定位

—–>absolute—自適應寬度元素絕對定位

注意:固定寬度列的高度>自適應寬度的列

示例

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>混合佈局編程挑戰</title>
<style type="text/css">
body{ margin:0; padding:0; font-size:30px; color:#fff}
.top{height:100px; background: #A9A9A9}
/*.main{background: red;  height: 600px; position: relative;}
.left{background: blue; width: 200px; height:100%; position: absolute; top: 0px}註釋的這個部分是採用絕對定位實現*/
.main{background: red; height: 600px;}
.left{background: blue; width: 200px; height:100%; float: left;}
.right{background:#20B2AA;  margin-left: 220px ;height:100%;}
.foot{height: 50px; background:#FF8C00;}
</style>

</head>

<body>
<div class="top">top</div>
<div class="main">
<!--    <div class="right">right</div>
    <div class="left">left</div> 註釋的這個部分是採用絕對定位實現--> 
    <div class="left">left</div>
    <div class="right">right</div>
</div>
<div class="foot">foot</div>

</body>
</html>

效果如下


層模型 – – 相對定位


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

相對於自身原有位置進行偏移

仍然處於標準文檔流中

隨即擁有偏移屬性和z-index屬性

如下代碼實現相對於以前位置向下移動50px,向右移動100px;

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

這裏寫圖片描述

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

大家可以做一個實驗,在示例代碼的19行div標籤的後面加入一個span標籤,在標並在span標籤中寫入一些文字。如下代碼:

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

這裏寫圖片描述

從效果圖中可以明顯的看出,雖然div元素相對於以前的位置產生了偏移,但是div元素以前的位置還是保留着,所以後面的span元素是顯示在了div元素以前位置的後面。

示例

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>relative樣式</title>
<style type="text/css">
#div1{
    width:100px;
    height:100px;
    border:2px red solid;
    position:relative;
    left:50px;
    top:50px;
}

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

層模型 – – 固定定位


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組合使用


小夥伴們學習了絕對定位的方法:使用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定位了(這裏注意參照物就可以不是瀏覽器了,而可以自由設置了)。

示例

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>相對參照元素進行定位</title>
<style type="text/css">
div{border:2px red solid;}
#box1{
    width:200px;
    height:200px;
    position:relative;

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

}
/*下面是任務部分*/
#box3{
    width:200px;
    height:200px;
    position:relative;    
}
#box4{
    width:99%;
    position:absolute;  
    bottom:0px;
    left:0px;
}
</style>
</head>

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

<h1>下面是任務部分</h1>
<div id="box3">
    <img src="http://img.com/2000200.jpg">
    <div id="box4">當我還是三年級的學生時是一個害羞的小女生。</div>
</div>
</body>
</html>

這裏寫圖片描述

案例一

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題文檔</title>
<style type="text/css">
*{margin:0; padding:0;}
#wrap{width:970px; margin: 0px auto}
#mainbody{position: relative; margin-top:15px;}
#left{width:110px; float: left; border:1px solid #999;}
#mid{width:650px;border:1px solid #999; float: left; margin-left: 13px}
#right{position: absolute; border:1px solid #999;left: 792px;}
</style>
</head>

<body>
<div id="wrap">
     <div id="header"><img src="http://img.mukewang.com/5369cd6e0001a15b09700088.jpg" width="970" height="88" /></div>
     <div id="mainbody">
          <div id="left"><img src="http://img.mukewang.com/5369cd0e00011e3901090487.jpg" width="109" height="487" /></div>
          <div id="mid"><img src="http://img.mukewang.com/5369cd3c00013e9e06490439.jpg" width="649" height="439" /></div>
          <div id="right"><p>歡迎使用金山軟件出品的愛詞霸,在線查詢你英語詞彙、句子釋義</p><img src="http://img.mukewang.com/5369cd540001d8e101770329.jpg" width="177" height="329" /></div>
  </div>
</div>
</body>
</html>

案例二

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>混合佈局</title>
<style>
body{ margin:0; padding:0; font-size:30px; font-weight:bold}
div{ text-align:center; line-height:50px}
.top{ height:100px;background:#9CF}
.head,.main{ width:760px; margin: 0px auto}
.head{ height:100px; background:#F90}
.left{ width:120px; height:600px; background:#ccc; float: left;}
.right{ width:640px; height:600px;background:#FCC; float: right}
.r_sub_left{ width:490px; height:600px; background:#9C3; float:left}
.r_sub_right{ width:150px; height:600px; background:#9FC; float: right;}
.footer{ height:50px; background:#9F9; clear: both;}
</style>
</head>

<body>
<div class="top">
    <div class="head">head</div>
</div>
<div class="main">
    <div class="left">left</div>
    <div class="right">
        <div class="r_sub_left">sub_left
        </div>
        <div class=" r_sub_right">sub_right
        </div>
    </div>
</div>
<div class="footer">footer</div>
</body>
</html>

案例一 案例一 案例二、 案例二

最後感謝 @婧享人生 老師讓我對網頁佈局基礎有了更深的理解。

發佈了40 篇原創文章 · 獲贊 20 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章