元素分類
在講解CSS布局之前,我們需要提前知道一些知識,在CSS中,html中的标簽元素大體被分為三種不同的類型:塊狀元素、内聯元素(又叫行内元素)和内聯塊狀元素。
常用的塊狀元素有:
<div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form>
常用的内聯元素有:
<a>、<span>、<br>、<i>、<em>、<strong>、<label>、<q>、<var>、<cite>、<code>
常用的内聯塊狀元素有:
<img>、<input>
元素分類--塊級元素
什麼是塊級元素?在html中<div>、 <p>、<h1>、<form>、<ul> 和 <li>就是塊級元素。設定
display:block
就是将元素顯示為塊級元素。如下代碼就是将内聯元素a轉換為塊狀元素,進而使a元素具有塊狀元素特點。
a{display:block;}
塊級元素特點:
1、每個塊級元素都從新的一行開始,并且其後的元素也另起一行。(真霸道,一個塊級元素獨占一行)
2、元素的高度、寬度、行高以及頂和底邊距都可設定。
3、元素寬度在不設定的情況下,是它本身父容器的100%(和父元素的寬度一緻),除非設定一個寬度。
display:block
a{display:block;}
元素分類--内聯元素
在html中,<span>、<a>、<label>、<input>、 <strong> 和<em>就是典型的内聯元素(行内元素)(inline)元素。當然塊狀元素也可以通過代碼
display:inline
将元素設定為内聯元素。如下代碼就是将塊狀元素div轉換為内聯元素,進而使 div 元素具有内聯元素特點。
div{
display:inline;
}
......
<div>我要變成内聯元素</div>
内聯元素特點:
1、和其他元素都在一行上;
2、元素的高度、寬度及頂部和底部邊距不可設定;
3、元素的寬度就是它包含的文字或圖檔的寬度,不可改變。
小夥伴們你們觀查一下右側代碼段,有沒有發現一個問題,内聯元素之間有一個間距問題,這個問題在本小節的 wiki 中有介紹,感興趣的小夥伴可以去檢視。
元素分類--内聯塊狀元素
内聯塊狀元素(inline-block)就是同時具備内聯元素、塊狀元素的特點,代碼
display:inline-block
就是将元素設定為内聯塊狀元素。(css2.1新增),<img>、<input>标簽就是這種内聯塊狀标簽。
inline-block 元素特點:
提示:下一小節是用視訊動畫來講解css中的盒模型。
display:inline-block

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>内聯塊狀元素</title>
<style type="text/css">
a{
display:inline-block;
width:20px;/*在預設情況下寬度不起作用*/
height:20px;/*在預設情況下高度不起作用*/
background:pink;/*設定背景顔色為粉色*/
text-align:center; /*設定文本居中顯示*/
}
</style>
</head>
<body>
<a>1</a>
<a>2</a>
<a>3</a>
<a>4</a>
</body>
</html>
View Code
盒模型--邊框(一)
盒子模型的邊框就是圍繞着内容及補白的線,這條線你可以設定它的粗細、樣式和顔色(邊框三個屬性)。
如下面代碼為 div 來設定邊框粗細為 2px、樣式為實心的、顔色為紅色的邊框:
div{
border:2px solid red;
}
上面是 border 代碼的縮寫形式,可以分開寫:
div{
border-width:2px;
border-style:solid;
border-color:red;
}
注意:
1、border-style(邊框樣式)常見樣式有:
dashed(虛線)| dotted(點線)| solid(實線)。
2、border-color(邊框顔色)中的顔色可設定為十六進制顔色,如:
border-color:#888;//前面的井号不要忘掉。
3、border-width(邊框寬度)中的寬度也可以設定為:
thin | medium | thick(但不是很常用),最常還是用象素(px)。

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>邊框</title>
<style type="text/css">
p{border:2px dotted #ccc;}
</style>
</head>
<body>
<h1>勇氣</h1>
<p>三年級時,我還是一個膽小如鼠的小女孩,上課從來不敢回答老師提出的問題,生怕回答錯了老師會批評我。就一直沒有這個勇氣來回答老師提出的問題。學校舉辦的活動我也沒勇氣參加。</p>
<p>到了三年級下學期時,我們班上了一節公開課,老師提出了一個很簡單的問題,班裡很多同學都舉手了,甚至成績比我差很多的,也舉手了,還說着:"我來,我來。"我環顧了四周,就我沒有舉手。</p>
</body>
</html>
盒模型--邊框(二)
現在有一個問題,如果有想為 p 标簽單獨設定下邊框,而其它三邊都不設定邊框樣式怎麼辦呢?css 樣式中允許隻為一個方向的邊框設定樣式:
div{border-bottom:1px solid red;}
同樣可以使用下面代碼實作其它三邊(上、右、左)邊框的設定:
border-top:1px solid red;
border-right:1px solid red;
border-left:1px solid red;
盒模型--寬度和高度
盒模型寬度和高度和我們平常所說的物體的寬度和高度了解是不一樣的,css内定義的寬(width)和高(height),指的是填充以裡的内容範圍。
是以一個元素實際寬度(盒子的寬度)=左邊界+左邊框+左填充+内容寬度+右填充+右邊框+右邊界。
元素的高度也是同理。
比如:
css代碼:
div{
width:200px;
padding:20px;
border:1px solid red;
margin:10px;
}
html代碼:
<body>
<div>文本内容</div>
</body>
元素的實際長度為:10px+1px+20px+200px+20px+1px+10px=262px。在chrome浏覽器下可檢視元素盒模型,如下圖:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>寬度和高度</title>
<style type="text/css">
li{
border-bottom:1px dotted #ccc;
width:200px;height:30px;
padding:20px;
margin:10px;
}
</style>
</head>
<body>
<ul>
<li>别讓不會說話害了你</li>
<li>二十七八歲就應該有的見識</li>
<li>别讓不好意思害了你</li>
</ul>
</body>
</html>
盒模型--填充
元素内容與邊框之間是可以設定距離的,稱之為“填充”。填充也可分為上、右、下、左(順時針)。如下代碼:
div{padding:20px 10px 15px 30px;}
順序一定不要搞混。可以分開寫上面代碼:
div{
padding-top:20px;
padding-right:10px;
padding-bottom:15px;
padding-left:30px;
}
如果上、右、下、左的填充都為10px;可以這麼寫
div{padding:10px;}
如果上下填充一樣為10px,左右一樣為20px,可以這麼寫:
div{padding:10px 20px;}

<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>填充</title>
<style type="text/css">
#box1{
width:100px;
height:100px;
padding:10px;
border:1px solid red;
}
</style>
</head>
<body>
<div id="box1">盒子1</div>
</body>
</html>
盒模型--邊界
元素與其它元素之間的距離可以使用邊界(margin)來設定。邊界也是可分為上、右、下、左。如下代碼:
div{margin:20px 10px 15px 30px;}
也可以分開寫:
div{
margin-top:20px;
margin-right:10px;
margin-bottom:15px;
margin-left:30px;
}
如果上右下左的邊界都為10px;可以這麼寫:
div{ margin:10px;}
div{ margin:10px 20px;}
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>邊距</title>
<style type="text/css">
div{
width:300px;
height:300px;
border:1px solid red;
}
#box1{margin-bottom:30px;}
</style>
</head>
<body>
<div id="box1">box1</div>
<div id="box2">box2</div>
</body>
</html>