css盒模型和塊級、行內(nèi)元素深入理解

一、CSS盒模型
盒模型概述
盒模型是CSS的核心知識點之一,它指定元素如何顯示以及如何相互交互。頁面上的每個元素都被看成一個矩形框,這個框由元素的內(nèi)容、內(nèi)邊距、邊框和外邊距組成。如下圖所示:
內(nèi)邊距出現(xiàn)在內(nèi)容區(qū)域的周圍。如果在元素上添加背景,那么背景應用于元素的內(nèi)容和內(nèi)邊距組成的區(qū)域。因此可以用內(nèi)邊距在內(nèi)容周圍創(chuàng)建一個隔離帶,使內(nèi)容不與背景混合在一起。添加邊框會在內(nèi)邊距區(qū)域外邊增加一條線。這些線可以有不同的樣式和寬度,如實線、虛線、點畫線。在邊框外邊的是外邊距,外邊距是透明的,一般使用它控制元素之間的間隔。
內(nèi)邊距、邊框和外邊距可以應用于一個元素的所有邊,也可以應用于單獨的邊,如:
padding-top:20px; //為元素單獨設(shè)置上內(nèi)邊距padding:15px; //元素的所有內(nèi)邊距都為15pxpadding:1px 2px 3px 4px; //分別為每個邊設(shè)置內(nèi)邊距,順序為 上 右 下 左 /*外邊距margin用法同內(nèi)邊距padding*/ border-top:1px solid #ccc; //為元素單獨設(shè)置上邊框border:2px dashed #000; //為所有邊設(shè)置邊框
標準模式與混雜模式下的盒模型
什么是標準模式和混雜模式
當瀏覽器廠商開始創(chuàng)建與標準兼容的瀏覽器時,他們希望確保向后兼容性。為了實現(xiàn)這一點,他們創(chuàng)建了兩種呈現(xiàn)模式:標準模式和混雜模式。在標準模式下瀏覽器按照規(guī)范呈現(xiàn)頁面;在混雜模式下,頁面以一種比較寬松的向后兼容的方式顯示?;祀s模式通常模擬老式瀏覽器的行為以防止老站點無法工作。
怎樣區(qū)分標準模式和混雜模式
瀏覽器根據(jù)DOCTYPE(文檔聲明)是否存在以及使用那種DTD來選擇要使用的呈現(xiàn)方式。如果XHTML和HTML文檔保航形式完整的DOCTYPE,那么它一般以標準模式呈現(xiàn)。相反,如果文檔的DOCTYPE不存在或者形式不正確則導致HTML和XHTML以混雜模式呈現(xiàn)。
兩種模式下的盒模型
標準模式下盒子的實際寬度為:
width + padding-left + padding-right + border-left-width + border-right-width
實際高度為:
heigth + padding-top +padding-bottom + border-top-width + border-bottom-width
混雜模式下盒子的實際寬度為:css中設(shè)定的width值,高度為設(shè)置的height值。當然在沒有設(shè)置overflow的情況下,若盒子內(nèi)容、內(nèi)邊距、或是邊框的值較大,會把盒子撐開,實際寬度和高度則大于設(shè)定值。
二、塊級元素與行內(nèi)元素
我們在做頁面布局的時候,一般會將html元素分為兩種,即塊級元素和行內(nèi)元素。
塊級元素:塊狀元素排斥其他元素與其位于同一行,可以設(shè)定元素的寬(width)和高(height),塊級元素一般是其他元素的容器,可容納塊級元素和行內(nèi)元素。常見的塊級元素有div, p ,h1~h6等。
行內(nèi)元素:行內(nèi)元素不可以設(shè)置寬(width)和高(height),但可以與其他行內(nèi)元素位于同一行,行內(nèi)元素內(nèi)一般不可以包含塊級元素。行內(nèi)元素的高度一般由元素內(nèi)部的字體大小決定,寬度由內(nèi)容的長度控制。常見的行內(nèi)元素有a, em ,strong等。
例如:我們可以給div或p應用下面樣式,但是a標簽卻無法應用下面的樣式。
.test{width:100px; height:100px;}
當然我們還可以通過樣式display屬性來改變元素的顯示方式。當display的值設(shè)為block時,元素將以塊級方式呈現(xiàn);當display值設(shè)為inline時,元素將以行內(nèi)形式呈現(xiàn)。所以我們可以給a標簽應用以下樣式:
.test{display:block; width:50px; height:50px;}
另外,如果我們即想讓一個元素可以設(shè)置寬度高度,又想讓它以行內(nèi)形式顯示,這時我們可以設(shè)置display的值為inline-block。如:
a{display:inline-block; width:100px; height:100px;}
相關(guān)文章
- CSS Grid 是一種二維布局系統(tǒng),可以同時控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋2025-04-16
CSS Padding 和 Margin 區(qū)別全解析
CSS 中的 padding 和 margin 是兩個非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細介紹 padding 和 margin 的概念、區(qū)別以及如何在實際項目中使用它們2025-04-07- will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧2025-04-07
- 本文給大家分享在 CSS 中,去除a標簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細,感興趣的朋友一起看看吧2025-04-07
- 在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實現(xiàn)復雜交互和動態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將2025-04-07
css中的 vertical-align與line-height作用詳解
文章詳細介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧2025-03-26淺析CSS 中z - index屬性的作用及在什么情況下會失效
z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用2025-03-21- 文章詳細介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁控制、調(diào)整邊距和背景等2025-03-18
CSS模擬 html 的 title 屬性(鼠標懸浮顯示提示文字效果)
本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標懸浮顯示提示文字效果,通過設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起2025-03-10前端 CSS 動態(tài)設(shè)置樣式::class、:style 等技巧(推薦)
本文介紹了Vue.js中動態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對象語法和數(shù)組語法,通過對象語法,可以根據(jù)條件動態(tài)切換類名或樣式;通過數(shù)組語法,可以同時綁定多個類名或樣式,此外2025-02-26