CSS(三)盒子模型

目錄

Content

Padding

Border

Margin

盒子模型計算方式

使用 box-sizing 屬性控制盒子模型的計算


所有的HTML元素都可以看作像下圖這樣一個矩形盒子:

這個模型包括了四個區域:content(內容區域)、padding(內邊距)、border(邊框)和 margin(外邊距)

Content

內容區域是盒子模型的最核心部分,包含了元素的實際內容,例如文本、圖片、視頻、按鈕等

內容區域的大小由元素的 widthheight 屬性決定。通常,CSS 的 widthheight 只會影響內容區域的尺寸,paddingbordermargin 不會計入該區域的尺寸。例如想要設置一個 div 元素的寬度為 300px,那么該 div 的內容區域的寬度就為 300px:

div {width: 300px;height: 150px;
}

Padding

內邊距是內容區域與邊框之間的空間,通過調整 padding,可以控制內容與邊框之間的距離

例如,增加內邊距可以使文本遠離邊框,提升可讀性

div {padding: 20px;
}

上述代碼會在 div 元素的所有邊緣(上、右、下、左)添加 20px 的內邊距

同樣,也可以單獨設置四個方向的內邊距:padding-toppadding-rightpadding-bottompadding-left

Border

邊框圍繞內容區域和內邊距的外部,是一個可視的邊界。邊框的樣式、寬度和顏色可以自定義

影響元素邊界的屬性:border-widthborder-styleborder-color

div {border: 3px solid black;
}

上述代碼會給 div 元素添加一個 3px 寬的黑色實線邊框

圓角邊框:

使用border-radius屬性來設置圓角框的半徑

border-radius:10px

border-radius 可以接收 1 到 4 個值,決定了每個角的半徑

  • 1個值:四個角相同
  • 2個值:第一個值為水平半徑,第二個值為垂直半徑
  • 3個值:前兩個為左右角,最后一個為上下角的半徑
  • 4個值:依次為左上、右上、右下、左下的圓角半徑

Margin

外邊距是盒子與其他元素之間的空隙,用來控制元素間的距離

外邊距不會影響元素的實際大小,但它會改變元素與其他元素之間的間距

div {margin: 20px;
}

上述代碼會在 div 元素的四個方向添加 20px 的外邊距,增加元素與其他元素之間的間距

同樣也可以設置四個單獨方向的外邊距:margin-topmargin-rightmargin-bottommargin-left

控制塊居中:

margin:auto;

盒子模型計算方式

默認情況下,CSS 中的寬度和高度只包括 內容區域,不包括內邊距、邊框和外邊距。

因此,元素的總大小大于其指定的 widthheight

總寬度 = 內容寬度 (width) + 左右內邊距 (padding-leftpadding-right) + 左右邊框 (border-leftborder-right) + 左右外邊距 (margin-leftmargin-right)

總高度 = 內容高度 (height) + 上下內邊距 (padding-toppadding-bottom) + 上下邊框 (border-topborder-bottom) + 上下外邊距 (margin-topmargin-bottom)

使用 box-sizing 屬性控制盒子模型的計算

box-sizing 屬性可以控制如何計算元素的寬度和高度。

它的取值為:

  • content-box(默認值):

    • 寬度和高度只包括內容區域,不包括內邊距和邊框
    • paddingborder 會額外增加在元素的尺寸上
  • border-box

    • 寬度和高度包括內容區域、內邊距和邊框的尺寸
    • 使用 border-box 后,設置的寬度和高度會包含 paddingborder,更符合直觀的布局

例如:

div {box-sizing: border-box;width: 300px;padding: 20px;border: 10px solid black;
}

在這種情況下,div 元素的總寬度是 300px,其中包含 paddingborder

如果使用 content-box,則總寬度將是 300px + 20px(padding-left)+ 20px(padding-right)+ 10px(border-left)+ 10px(border-right)= 360px

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/64181.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/64181.shtml
英文地址,請注明出處:http://en.pswp.cn/web/64181.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

基于NodeMCU的物聯網窗簾控制系統設計

最終效果 基于NodeMCU的物聯網窗簾控制系統設計 項目介紹 該項目是“物聯網實驗室監測控制系統設計(仿智能家居)”項目中的“家電控制設計”中的“窗簾控制”子項目,最前者還包括“物聯網設計”、“環境監測設計”、“門禁系統設計計”和“小…

有沒有免費提取音頻的軟件?音頻編輯軟件介紹!

出于工作和生活娛樂等原因,有時候我們需要把音頻單獨提取出來(比如歌曲伴奏、人聲清唱等、樂器獨奏等)。要提取音頻必須借助音頻處理軟件,那么有沒有免費提取音頻的軟件呢?下面我們將為大家介紹幾款免費軟件&#xff0…

WPF自定義窗口 輸入驗證不生效

WPF自定義窗口 輸入驗證不生效 WPF ValidationRule 不生效 WPF ValidationRule 不生效 解決方案&#xff1a;在WindowStyle的Template中添加AdornerDecorator標簽。 <Style x:Key"WindowStyle1" TargetType"{x:Type Window}"><Setter Property&…

【保姆式】python調用api通過機器人發送文件到飛書指定群聊

當前飛書webhook機器人還不支持發送文件類型的群消息&#xff0c;它目前僅支持文本&#xff0c;富文本&#xff0c;卡片等文字類型的數據。 我們可以申請創建一個機器人應用來實現群發送文件消息。 創建飛書應用 創建飛書應用、配置權限、添加機器人 來到飛書開發者后臺 創建…

MySQL-存儲過程(頭歌數據庫實驗題)

&#xff08;學校數據庫課程的頭歌平臺實驗題&#xff0c;根據自己理解編寫&#xff0c;希望對正在學的人有啟發作用和借鑒幫助&#xff0c;不喜勿噴&#xff0c;有錯請聯系改正&#xff09; 實驗 存儲過程&#xff1a;輸入1 任務描述&#xff1a; 本關任務&#xff1a;編寫…

GitLab 服務變更提醒:中國大陸、澳門和香港用戶停止提供服務(GitLab 服務停止)

目錄 前言 一. 變更詳情 1. 停止服務區域 2. 郵件通知 3. 新的服務提供商 4. 關鍵日期 5. 行動建議 二. 遷移指南 三. 注意事項 四. 相關推薦 前言 近期&#xff0c;許多位于中國大陸、澳門和香港的 GitLab 用戶收到了一封來自 GitLab 官方的重要通知。根據這封郵件…

mysql基礎快速入門

通用語法及分類 DDL: 數據定義語言&#xff0c;用來定義數據庫對象&#xff08;數據庫、表、字段&#xff09;DML: 數據操作語言&#xff0c;用來對數據庫表中的數據進行增刪改DQL: 數據查詢語言&#xff0c;用來查詢數據庫中表的記錄DCL: 數據控制語言&#xff0c;用來創建數…

Python文件讀寫在“簡易記事本”項目中的應用

Python文件讀寫在“簡易記事本”項目中的應用 文件讀寫是“簡易記事本”項目實現數據持久化的關鍵部分。在本節中&#xff0c;我們將逐步拆解記事本的功能&#xff0c;詳細講解與文件讀寫相關的代碼&#xff0c;并結合實際操作幫助讀者更好地理解文件操作的核心知識點。 功能…

【Agent】AutoGen Studio2.0開源框架-UI層環境安裝+詳細操作教程(從0到1帶跑通智能體AutoGen Studio)

&#x1f4a5; 歡迎來到我的博客&#xff01;很高興能在這里與您相遇&#xff01; 首頁&#xff1a;GPT-千鑫 – 熱愛AI、熱愛Python的天選打工人&#xff0c;活到老學到老&#xff01;&#xff01;&#xff01;導航 - 人工智能系列&#xff1a;包含 OpenAI API Key教程, 50個…

三層交換機配置

一&#xff0c;三層交換 概念&#xff1a;三層交換技術就是&#xff1a;二層交換技術三層轉發技術(路由器功能)。它解決了局域網中網段劃分之后&#xff0c;網段中子網必須依賴路由器進行管理的局面&#xff0c;解決了傳統路由器低速&#xff0c;復雜所造成的網絡瓶頸問題。 …

js單例模式

單例模式是一種常見的設計模式&#xff0c;在JavaScript中也有廣泛應用&#xff0c;以下是關于它的詳細介紹&#xff1a; 定義 單例模式是一種創建型設計模式&#xff0c;它確保一個類只有一個實例&#xff0c;并提供一個全局訪問點來訪問該實例。在JavaScript中&#xff0c;…

【Golang 面試題】每日 3 題(六)

?個人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;專欄地址&#xff1a;http://t.csdnimg.cn/UWz06 &#x1f4da;專欄簡介&#xff1a;在這個專欄中&#xff0c;我將會分享 Golang 面試中常見的面試題給大家~ ??如果有收獲的話&#xff0c;歡迎點贊&#x1f44d;收藏…

SQL Server數據庫多主模式解決方案

SQL Server 本身并不直接支持多主模式(Multi-Master Replication),即多個數據庫實例可以同時進行寫操作,并且這些更改會自動同步到其他實例。不過,SQL Server 提供了多種高可用性和復制解決方案,可以實現類似多主模式的功能。以下是幾種常見的方法: 1. Always On 可用性…

連鎖餐飲行業數據可視化分析方案

引言 隨著連鎖餐飲行業的迅速發展&#xff0c;市場競爭日益激烈。企業需要更加精準地把握運營狀況、消費者需求和市場趨勢&#xff0c;以制定科學合理的決策&#xff0c;提升競爭力和盈利能力。可視化數據分析可以幫助連鎖餐飲企業整合多源數據&#xff0c;通過直觀、動態的可…

Zookeeper JavaAPI操作(Curator API常用操作)

構建項目 zk版本&#xff1a;3.5.7&#xff0c;引入4.0.0的curator版本&#xff0c;Curator依賴的版本只能比zookeeper依賴的版本高。 Curator簡單介紹 Curator是Netflix公司開源的一套zookeeper客戶端框架&#xff0c;解決了很多Zookeeper客戶端非常底層的細節開發工作&…

可搜索的下拉選擇框:filterable屬性詳解

在前端開發中&#xff0c;下拉選擇框&#xff08;Dropdown Select&#xff09;是一個常見的UI組件&#xff0c;它允許用戶從一組預定義的選項中選擇一個或多個值。然而&#xff0c;當選項數量較多時&#xff0c;手動查找特定的選項可能會變得繁瑣。為了解決這個問題&#xff0c…

精選9個自動化任務的Python腳本精選

大家好&#xff0c;我是老鄧&#xff0c;今天我們來一起學習如何用Python進行一些常見的自動化操作&#xff0c;涉及文件處理、網絡交互等實用技巧。即使你沒有任何Python基礎也沒關系&#xff0c;我會用最通俗易懂的語言來講解。 1. 對目錄中的文件進行排序 import osdef so…

滑動窗口 + 算法復習

維護一個滿足條件的窗口大小&#xff0c;然后進行雙指針移動 1.最長子串 題目鏈接&#xff1a;1.最長子串 - 藍橋云課 #include<bits/stdc.h> #define int long long using namespace std; string s; int k; signed main() {int max_len0,left0;cin>>s>>k;…

PDF書籍《手寫調用鏈監控APM系統-Java版》第9章 插件與鏈路的結合:Mysql插件實現

本人閱讀了 Skywalking 的大部分核心代碼&#xff0c;也了解了相關的文獻&#xff0c;對此深有感悟&#xff0c;特此借助巨人的思想自己手動用JAVA語言實現了一個 “調用鏈監控APM” 系統。本書采用邊講解實現原理邊編寫代碼的方式&#xff0c;看本書時一定要跟著敲代碼。 作者…

關于Vue的子組件改變父組件傳來的值

一、組件直接傳值 大家都知道父子組件傳值的方案&#xff0c;有以下幾個&#xff0c;不再詳細敖述 Props&#xff1a;父組件向子組件傳遞數據 $emit&#xff1a;子組件通過自定義事件向父組件傳遞數據 .sync修飾符&#xff1a;一個方便且強大的工具&#xff0c;可以簡化父子組…