欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

  發(fā)布時間:2012-12-24 09:21:55   作者:佚名   我要評論
盒模型是CSS的核心知識點(diǎn)之一,它指定元素如何顯示以及如何相互交互。頁面上的每個元素都被看成一個矩形框,這個框由元素的內(nèi)容、內(nèi)邊距、邊框和外邊距組成,需要了解的朋友可以深入?yún)⒖枷?/div>

一、CSS盒模型

盒模型概述

盒模型是CSS的核心知識點(diǎn)之一,它指定元素如何顯示以及如何相互交互。頁面上的每個元素都被看成一個矩形框,這個框由元素的內(nèi)容、內(nèi)邊距、邊框和外邊距組成。如下圖所示:

內(nèi)邊距出現(xiàn)在內(nèi)容區(qū)域的周圍。如果在元素上添加背景,那么背景應(yīng)用于元素的內(nèi)容和內(nèi)邊距組成的區(qū)域。因此可以用內(nèi)邊距在內(nèi)容周圍創(chuàng)建一個隔離帶,使內(nèi)容不與背景混合在一起。添加邊框會在內(nèi)邊距區(qū)域外邊增加一條線。這些線可以有不同的樣式和寬度,如實(shí)線、虛線、點(diǎn)畫線。在邊框外邊的是外邊距,外邊距是透明的,一般使用它控制元素之間的間隔。

內(nèi)邊距、邊框和外邊距可以應(yīng)用于一個元素的所有邊,也可以應(yīng)用于單獨(dú)的邊,如:

復(fù)制代碼
代碼如下:

padding-top:20px; //為元素單獨(dú)設(shè)置上內(nèi)邊距padding:15px; //元素的所有內(nèi)邊距都為15pxpadding:1px 2px 3px 4px; //分別為每個邊設(shè)置內(nèi)邊距,順序?yàn)?上 右 下 左 /*外邊距margin用法同內(nèi)邊距padding*/ border-top:1px solid #ccc; //為元素單獨(dú)設(shè)置上邊框border:2px dashed #000; //為所有邊設(shè)置邊框
 
標(biāo)準(zhǔn)模式與混雜模式下的盒模型

什么是標(biāo)準(zhǔn)模式和混雜模式

當(dāng)瀏覽器廠商開始創(chuàng)建與標(biāo)準(zhǔn)兼容的瀏覽器時,他們希望確保向后兼容性。為了實(shí)現(xiàn)這一點(diǎn),他們創(chuàng)建了兩種呈現(xiàn)模式:標(biāo)準(zhǔn)模式和混雜模式。在標(biāo)準(zhǔn)模式下瀏覽器按照規(guī)范呈現(xiàn)頁面;在混雜模式下,頁面以一種比較寬松的向后兼容的方式顯示?;祀s模式通常模擬老式瀏覽器的行為以防止老站點(diǎn)無法工作。

怎樣區(qū)分標(biāo)準(zhǔn)模式和混雜模式

瀏覽器根據(jù)DOCTYPE(文檔聲明)是否存在以及使用那種DTD來選擇要使用的呈現(xiàn)方式。如果XHTML和HTML文檔保航形式完整的DOCTYPE,那么它一般以標(biāo)準(zhǔn)模式呈現(xiàn)。相反,如果文檔的DOCTYPE不存在或者形式不正確則導(dǎo)致HTML和XHTML以混雜模式呈現(xiàn)。

兩種模式下的盒模型

standard mode

標(biāo)準(zhǔn)模式下盒子的實(shí)際寬度為:

width + padding-left + padding-right + border-left-width + border-right-width

實(shí)際高度為:

heigth + padding-top +padding-bottom + border-top-width + border-bottom-width

quirks mode

混雜模式下盒子的實(shí)際寬度為:css中設(shè)定的width值,高度為設(shè)置的height值。當(dāng)然在沒有設(shè)置overflow的情況下,若盒子內(nèi)容、內(nèi)邊距、或是邊框的值較大,會把盒子撐開,實(shí)際寬度和高度則大于設(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應(yīng)用下面樣式,但是a標(biāo)簽卻無法應(yīng)用下面的樣式。

復(fù)制代碼
代碼如下:

.test{width:100px; height:100px;}

當(dāng)然我們還可以通過樣式display屬性來改變元素的顯示方式。當(dāng)display的值設(shè)為block時,元素將以塊級方式呈現(xiàn);當(dāng)display值設(shè)為inline時,元素將以行內(nèi)形式呈現(xiàn)。所以我們可以給a標(biāo)簽應(yīng)用以下樣式:

復(fù)制代碼
代碼如下:

.test{display:block; width:50px; height:50px;}

另外,如果我們即想讓一個元素可以設(shè)置寬度高度,又想讓它以行內(nèi)形式顯示,這時我們可以設(shè)置display的值為inline-block。如:

復(fù)制代碼
代碼如下:

a{display:inline-block; width:100px; height:100px;}

相關(guān)文章

  • 前端CSS Grid 布局示例詳解

    CSS Grid 是一種二維布局系統(tǒng),可以同時控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋
    2025-04-16
  • CSS Padding 和 Margin 區(qū)別全解析

    CSS 中的 padding 和 margin 是兩個非常基礎(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實(shí)際項(xiàng)目中使用它們
    2025-04-07
  • CSS will-change 屬性示例詳解

    will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧
    2025-04-07
  • CSS去除a標(biāo)簽的下劃線的幾種方法

    本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2025-04-07
  • 前端高級CSS用法示例詳解

    在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實(shí)現(xiàn)復(fù)雜交互和動態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將
    2025-04-07
  • css中的 vertical-align與line-height作用詳解

    文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧
    2025-03-26
  • 淺析CSS 中z - index屬性的作用及在什么情況下會失效

    z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用
    2025-03-21
  • CSS @media print 使用詳解

    文章詳細(xì)介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁控制、調(diào)整邊距和背景等
    2025-03-18
  • CSS模擬 html 的 title 屬性(鼠標(biāo)懸浮顯示提示文字效果)

    本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標(biāo)懸浮顯示提示文字效果,通過設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實(shí)現(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

最新評論