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

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

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

一、CSS盒模型

盒模型概述

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

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

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

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

padding-top:20px; //為元素單獨(dú)設(shè)置上內(nèi)邊距padding:15px; //元素的所有內(nèi)邊距都為15pxpadding:1px 2px 3px 4px; //分別為每個(gè)邊設(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í),他們希望確保向后兼容性。為了實(shí)現(xiàn)這一點(diǎn),他們創(chuàng)建了兩種呈現(xiàn)模式:標(biāo)準(zhǔn)模式和混雜模式。在標(biāo)準(zhǔn)模式下瀏覽器按照規(guī)范呈現(xiàn)頁(yè)面;在混雜模式下,頁(yè)面以一種比較寬松的向后兼容的方式顯示。混雜模式通常模擬老式瀏覽器的行為以防止老站點(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)邊距、或是邊框的值較大,會(huì)把盒子撐開,實(shí)際寬度和高度則大于設(shè)定值。

二、塊級(jí)元素與行內(nèi)元素

我們?cè)谧鲰?yè)面布局的時(shí)候,一般會(huì)將html元素分為兩種,即塊級(jí)元素和行內(nèi)元素。

塊級(jí)元素:塊狀元素排斥其他元素與其位于同一行,可以設(shè)定元素的寬(width)和高(height),塊級(jí)元素一般是其他元素的容器,可容納塊級(jí)元素和行內(nèi)元素。常見的塊級(jí)元素有div, p ,h1~h6等。

行內(nèi)元素:行內(nèi)元素不可以設(shè)置寬(width)和高(height),但可以與其他行內(nèi)元素位于同一行,行內(nèi)元素內(nèi)一般不可以包含塊級(jí)元素。行內(nèi)元素的高度一般由元素內(nèi)部的字體大小決定,寬度由內(nèi)容的長(zhǎng)度控制。常見的行內(nèi)元素有a, em ,strong等。

例如:我們可以給div或p應(yīng)用下面樣式,但是a標(biāo)簽卻無法應(yīng)用下面的樣式。

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

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

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

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

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

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

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

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

相關(guān)文章

  • 前端CSS Grid 布局示例詳解

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

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

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

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

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

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

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

    文章詳細(xì)介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場(chǎng)景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁(yè)控制、調(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 動(dòng)態(tài)設(shè)置樣式::class、:style 等技巧(推薦)

    本文介紹了Vue.js中動(dòng)態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對(duì)象語法和數(shù)組語法,通過對(duì)象語法,可以根據(jù)條件動(dòng)態(tài)切換類名或樣式;通過數(shù)組語法,可以同時(shí)綁定多個(gè)類名或樣式,此外
    2025-02-26

最新評(píng)論