從零開始學習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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...