從零開始學習html(十一)CSS盒模型——上

来源:http://www.cnblogs.com/guxinglang/archive/2017/05/14/6803214.html
-Advertisement-
Play Games

一、元素分類 在CSS中,html中的標簽元素大體被分為三種不同的類型:塊狀元素、內聯元素(又叫行內元素)和內聯塊狀元素。 常用的塊狀元素有: <div>、<p>、<h1>...<h6>、<ol>、<ul>、<dl>、<table>、<address>、<blockquote> 、<form> 常用 ...


一、元素分類

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

二、元素分類--塊級元素

 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{background:pink;}
 8 </style>
 9 </head>
10 <body>
11 <div>div1</div>
12 <div>div2</div>
13 <p>段落1段落1段落1段落1段落1</p>
14 </body>
15 </html>
元素分類--塊級元素

什麼是塊級元素?在html中<div>、 <p>、<h1>、<form>、<ul> 和 <li>就是塊級元素。

設置display:block就是將元素顯示為塊級元素。如下代碼就是將內聯元素a轉換為塊狀元素,從而使a元素具有塊狀元素特點。

a{display:block;}

塊級元素特點:

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

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

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

來試一試:感受一下塊級元素的特點

在代碼編輯器中輸入各種塊級標簽,試一試他們的特點。

 

三、元素分類--內聯元素

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 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>
元素分類--內聯元素

在html中,<span>、<a>、<label>、 <strong> 和<em>就是典型的內聯元素(行內元素)(inline)元素。

當然塊狀元素也可以通過代碼display:inline將元素設置為內聯元素。如下代碼就是將塊狀元素div轉換為內聯元素,從而使 div 元素具有內聯元素特點。

 div{
     display:inline;
 }

......

<div>我要變成內聯元素</div>

內聯元素特點:

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

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

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

內聯元素之間有一個間距問題。

來試一試:感受一下內聯元素的特點

在代碼編輯器中輸入各種內聯元素標簽,試一試他們的特點。

 

行內元素之間會產生間隙bug問題的場景:
1、當行內元素之間有“回車”、“tab”、“空格”時就會出現間隙。
如下代碼:
<div>
<a>1</a>
<a>2</a>
<span>33333</span>
<span>44444</span>
<em>555555</em>
</div>

解決方法:
1、寫在一行,之間不要有空格之類的符號。

2、使用font-size:0
div{font-size:0;}
a,span,em{font-size:16px;}

如果你想讓div{font-size: 0;}起作用,請將行內元素包裹在裡面,就想這樣:
<div>
<a>我是鏈接</a>
<span>我是行空間</span>
</div>  

四、元素分類--內聯塊狀元素

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 5 <title>內聯塊狀元素</title>
 6 <style type="text/css">
 7 a{
 8     
 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>
元素分類--內聯塊狀元素

內聯塊狀元素(inline-block)就是同時具備內聯元素、塊狀元素的特點,

代碼display:inline-block就是將元素設置為內聯塊狀元素。(css2.1新增),<img>、<input>標簽就是這種內聯塊狀標簽。

inline-block 元素特點:

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

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

來試試,仿分頁頁碼設計

在代碼編輯器中大家可以看到我們為 a 元素設置了寬和高,但都沒有起到作用,

原因是a在預設的時候是內聯元素,內聯元素是不可以設置寬和高的。

在編輯器的第8行,輸入:

display:inline-block;

 

將塊元素或行內元素轉換為行塊內元素:是為後面的課程做鋪墊,

你只要知道行內元素不能設置高寬,轉換後可以設置就行了,塊狀元素不能在一行顯示轉換後可以在一行顯示就行了。

a標簽變為內聯塊狀元素後,居中設置的意思是,數字在每一個塊內裡面是居中顯示的,而不是整個a標簽在頁面上居中

inline:內聯元素{
1,不能設置width和height;
2,多個行內元素排成一行,直到一行排不下,才會換新一行;
3,只可以設置水平方向的邊距,如:margin-left,margin-right,padding-left,padding-right.
}
block:塊級元素{
1,塊級元素獨占一行;
2,可以設置width和height,預設寬度為一整行,除非單獨設置寬度;
3,可以設置margin和padding屬性。
}
inline-block{
簡而言之就是讓元素既可以在一行內顯示,又可以設置寬高邊距等。
}

 


塊級元素預設占一整行 無論它的寬有沒有一整行寬 沒用完的空間不准其他元素使用

屬性:display:block;

預設占一整行 預設寬度一整行 可以設置寬高 一行只有自己

 

內聯(行內)元素 定義的是一段內容(文本)這一行內沒占用完的空間其他內聯元素可以共同使用

屬性:display:inline;

沒法設置寬高 一行可以有多個 大小由內容決定

 

內聯塊狀元素(行內塊級元素)

屬性:display:inline-block;

可以設置寬高

一行能有多個

五、什麼是盒模型

視頻課程

 

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1 2 3 4 5 Title 6 66 67 68 69 ———中華瑰寶,絕美唐詩。 70 71 72 73 向晚意不適, 74 驅車登古原。 75 夕陽無限好, 76 ... ...
  • 很久之前就想自己搭一個博客了,最開始用hexo+github,但是換電腦後總是有些麻煩。後來使用WordPress,但是用WordPress總覺得沒什麼技術含量,前後端都是人家寫好的,而且買的垃圾虛擬機老是出問題,動不動就要提交工單解決,所以最後乾脆就直接在博客園上寫了。 最近比較閑,所以正好抽時間 ...
  • 目前,在PHP中是不支持字面量命名法。 前端的小伙伴都知道,在JS中用字面量定義一個對象的方法可以如下: 但在PHP中這麼定義對象: 則會報錯 Parse error: syntax error, unexpected '{' in D:\server\htdocs\xm\data\04_produ ...
  • 誰調用了函數,this就指向誰 >>> this指向的永遠只可能是對象!!! >>> this指向誰,永遠不取決於this寫在哪,而是取決於函數在哪調用!!! >>> this指向的對象,我們稱之為函數的上下文 context,也叫做函數的調用者 this指向的規律(浩哥五條黃金定律!!!)this ...
  • 記得第一次接觸xss這個概念是在高中,那個時候和一個好基友通過黑客X檔案和黑客手冊。第一次接觸到了除了游戲以外的電腦知識,然後知道了,原來電腦除了玩游戲還可以搞這些,從此兩人一發不可收拾的愛上了玩黑這方面的東西。 現在想起來,高中時期是在08年左右,那個時候的網路安全環境還蠻差。那個時候沒什麼電腦 ...
  • 要實現手機端橫向滑動效果並不難,瞭解實現的原理及業務邏輯就很容易實現。原理:touchstart(手指按下瞬間獲取相對於頁面的位置)——》touchmove(手指移動多少,元素相應移動多少)。 接下來講講實現邏輯: 其實就是手指拖動列表向哪個方向移動多少像素,並設置左右拖動的邊界值。 附上代碼及註釋 ...
  • 如果你是一個人在自學前端開發,或者是對前端開發有比較濃厚的興趣正想踏入前端領域,只要你在前端自學路上遇到了自己無法解決的技術難題,那麼儘管將你的疑惑交給我的小伙伴兒們吧,我們都是一群在前端自學路上摸爬滾打的有志青年,希望你可以來和我們共同交流。同時也希望你能獻出自己的一份力,幫助我的小伙伴兒們解決他 ...
  • 概述 面向過程與面向對象面向過程:專註於如何去解決一個問題的過程,編程特點是用一個個函數去實現過程操作,沒有類與對象的概念面向對象:專註於有哪一個對象實體去解決這個問題,編程特點是:出現了一個個的類,由類去生成對象。面向對象的三大特征:繼承,封裝,多態 對象和類的概念 類是抽象的,對象是具體的(類是 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...