HTML+CSS之CSS盒模型

摘要:本文學習CSS盒模型。


1 元素分類

在講解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>


2 元素分類--塊級元素

什麼是塊級元素?在html中<div>、 <p>、<h1>、<form>、<ul> 和 <li>就是塊級元素。設置display:block就是將元素顯示爲塊級元素。如下代碼就是將內聯元素a轉換爲塊狀元素,從而使a元素具有塊狀元素特點。

a{display:block;}

塊級元素特點:

1、每個塊級元素都從新的一行開始,並且其後的元素也另起一行。(真霸道,一個塊級元素獨佔一行)

2、元素的高度、寬度、行高以及頂和底邊距都可設置。

3、元素寬度在不設置的情況下,是它本身父容器的100%(和父元素的寬度一致),除非設定一個寬度。

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5. <title>內聯塊狀元素</title>  
  6. <style type="text/css">  
  7. div,p,h1{background:pink;}  
  8. </style>  
  9. </head>  
  10. <body>  
  11. <h1>this is h1</h1>  
  12. <h1>this is h1, too</h1>  
  13. <div>div1</div>  
  14. <div>div2</div>  
  15. <p>段落1段落1段落1段落1段落1</p>  
  16. </body>  
  17. </html>  



3 元素分類--內聯元素

在html中,<span>、<a>、<label>、<input>、 <img>、 <strong> 和<em>就是典型的內聯元素行內元素)(inline)元素。當然塊狀元素也可以通過代碼display:inline將元素設置爲內聯元素。如下代碼就是將塊狀元素div轉換爲內聯元素,從頁使用div元素具有內聯元素特點。

內聯元素特點:

1、和其他元素都在一行上;

2、元素的高度、寬度、行高及頂部和底部邊距不可設置;

3、元素的寬度就是它包含的文字或圖片的寬度,不可改變。

注意:內聯元素之間有一個間距問題,當行內元素之間有“回車”、“tab”、“空格”時就會出現間隙。

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  5. <title>行內元素標籤</title>  
  6. <style type="text/css">  
  7. a,span,em{  
  8.     background:pink;/*設置a、span、em標籤背景顏色都爲粉色*/  
  9. }  
  10. </style>  
  11. </head>  
  12. <body>  
  13. <a href="http://www.baidu.com">百度</a>  
  14. <a href="http://www.imooc.com">慕課網</a>  
  15. <span>33333</span>  
  16. <span>44444</span><em>555555</em>  
  17. </body>  
  18. </html>  



4 元素分類--內聯塊狀元素

內聯塊狀元素(inline-block就是同時具備內聯元素、塊狀元素的特點,代碼display:inline-block就是將元素設置爲內聯塊狀元素。(css2.1新增),<img>、<input>標籤就是這種內聯塊狀標籤。

inline-block元素特點:

1、和其他元素都在一行上;

2、元素的高度、寬度、行高以及頂和底邊距都可設置。

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
  5. <title>內聯塊狀元素</title>  
  6. <style type="text/css">  
  7. a{  
  8.     display:inline-block;  
  9.     width:20px;/*在默認情況下寬度不起作用*/  
  10.     height:20px;/*在默認情況下高度不起作用*/  
  11.     background:pink;/*設置背景顏色爲粉色*/  
  12.     text-align:center; /*設置文本居中顯示*/  
  13. }  
  14. </style>  
  15. </head>  
  16. <body>  
  17. <a>1</a>  
  18. <a>2</a>  
  19. <a>3</a>  
  20. <a>4</a>  
  21. </body>  
  22. </html>  



5 盒模型--邊框(一)

盒子模型的邊框就是圍繞着內容及補白的線,這條線你可以設置它的粗細、樣式和顏色(邊框三個屬性)。

如下面代碼爲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)。

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5. <title>邊框</title>  
  6. <style type="text/css">  
  7. p{border:2px dotted #ccc;}  
  8. </style>  
  9. </head>  
  10. <body>  
  11.     <h1>勇氣</h1>  
  12.     <p>三年級時,我還是一個膽小如鼠的小女孩,上課從來不敢回答老師提出的問題,生怕回答錯了老師會批評我。就一直沒有這個勇氣來回答老師提出的問題。學校舉辦的活動我也沒勇氣參加。</p>  
  13.     <p>到了三年級下學期時,我們班上了一節公開課,老師提出了一個很簡單的問題,班裏很多同學都舉手了,甚至成績比我差很多的,也舉手了,還說着:"我來,我來。"我環顧了四周,就我沒有舉手。</p>     
  14. </body>  
  15. </html>  


6 盒模型--邊框(二)

現在有一個問題,如果有想爲p標籤單獨設置下邊框,而其它三邊都不設置邊框樣式怎麼辦呢?css樣式中允許只爲一個方向的邊框設置樣式:

div{border-bottom:1px solid red;}

同樣可以使用下面代碼實現其它三邊上、右、左邊框的設置:

border-top:1px solid red;
border-right:1px solid red; 
border-left:1px solid red;

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5. <title>邊框</title>  
  6. <style type="text/css">  
  7. li{  
  8.     border-bottom:1px dotted #ccc;  
  9. }  
  10. </style>  
  11. </head>  
  12. <body>  
  13. <ul>  
  14.     <li>別讓不會說話害了你</li>  
  15.     <li>二十七八歲就應該有的見識</li>  
  16.     <li>別讓不好意思害了你</li>  
  17. </ul>  
  18. </body>  
  19. </html>  



7 盒模型--寬度和高度

盒模型寬度和高度和我們平常所說的物體的寬度和高度理解是不一樣的,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瀏覽器下可查看元素盒模型,如下圖:

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5. <title>寬度和高度</title>  
  6. <style type="text/css">  
  7. li{  
  8.     border-bottom:1px dotted #ccc;  
  9.     width:200px;height:30px;  
  10. }  
  11. </style>  
  12. </head>  
  13. <body>  
  14. <ul>  
  15.     <li>別讓不會說話害了你</li>  
  16.     <li>二十七八歲就應該有的見識</li>  
  17.     <li>別讓不好意思害了你</li>  
  18. </ul>  
  19. </body>  
  20. </html>  

注意:上一節中的列表項長度爲什麼這麼長啊,不明白同學是不是應該看一看標籤分類那一小節,li是塊狀元素,塊狀元素有一個特點之一:在不設置寬度的情況下,顯示爲父容器的100%


8 盒模型--填充

元素內容邊框之間是可以設置距離的,稱之爲“填充”。填充也可分爲上、右、下、左(順時針)。如下代碼:

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;}

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5. <title>填充</title>  
  6. <style type="text/css">  
  7. #box1{  
  8.     width:100px;  
  9.     height:100px;  
  10.     padding:10px;  
  11.     border:1px solid red;  
  12. }  
  13. </style>  
  14. </head>  
  15. <body>  
  16. <div id="box1">盒子1</div>  
  17. </body>  
  18. </html>  



9 盒模型--邊界

元素與其它元素之間的距離可以使用邊界(margin)來設置。邊界也是可分爲上、右、下、左。如下代碼:

div{margin:20px 10px 15px 30px;}

也可以分開寫:

div{
   margin-top:20px;
   margin-right:10px;
   margin-bottom:15px;
   margin-left:30px;
}

如果上右下左的邊界都爲10px;可以這麼寫:

div{ margin:10px;}

如果上下邊界一樣爲10px,左右一樣爲20px,可以這麼寫:

div{ margin:10px 20px;}

總結一下:padding和margin的區別,padding在邊框裏,margin在邊框外。

[html] view plain copy
 print?在CODE上查看代碼片派生到我的代碼片
  1. <!DOCTYPE HTML>  
  2. <html>  
  3. <head>  
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  
  5. <title>邊距</title>  
  6. <style type="text/css">  
  7. div{  
  8.     width:300px;  
  9.     height:300px;  
  10.     border:1px solid red;     
  11. }  
  12. #box1{margin-bottom:30px;}  
  13. </style>  
  14. </head>  
  15. <body>  
  16.     <div id="box1">box1</div>  
  17.     <div id="box2">box2</div>     
  18. </body>  
  19. </html>  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章