主頁 >  其他 > 檔案流、盒子模型、內邊距、外邊距、盒子模型水平方向的布局、盒子模型垂直方向的布局、盒子模型外邊距的折疊、行內元素的盒模型(萌新必看,大佬隨便)

檔案流、盒子模型、內邊距、外邊距、盒子模型水平方向的布局、盒子模型垂直方向的布局、盒子模型外邊距的折疊、行內元素的盒模型(萌新必看,大佬隨便)

2020-11-09 19:48:05 其他

《個人學習筆記十四》

文章目錄

    • 《個人學習筆記十四》
    • 檔案流(normal flow)
    • 盒子模型
    • 盒模型、盒子模型、框模型(box model)
    • 內邊距(padding)
    • 外邊距(margin)
    • 盒子模型水平方向的布局
    • 盒子模型垂直方向的布局
    • 盒子模型外邊距的折疊
    • 行內元素的盒模型


檔案流(normal flow)

  • 網頁是一個多層的結構,一層摞著一層
  • 通過css可以分別為每一層來設計樣式
  • 作為用戶來講只能看到最頂上一層
  • 這些層中,最底下的一層是檔案流,檔案流是網頁的基礎
  • 我們所創建的元素默認都是在檔案流中進行排列
  • 對于我們來說檔案流主要有兩個狀態
  1. 在檔案流中
  2. 不在檔案流中(脫離檔案流)

元素在檔案流中有什么特點:
塊元素

  • 塊元素會在頁面獨占一行(自上而下垂直排列)
  • 默認寬度是父元素的全度(會把父元素撐滿)
  • 默認高度是唄內容撐開的(子元素)

行內元素

  • 行內元素不會獨占頁面的一行,只占自身的大小
  • 行內元素在頁面中左向右水平排列,如果一行之中不能容納下所有的行內元素,則元素會換到第二行繼續從左向右排列(書寫習慣一致)
  • 行內元素的默認寬度和高度都是被內容撐開的

盒子模型

內容區

(content),元素中的所有的子元素和文本內容都是在內容區中排列

  • 內容區的大小有width和height兩個屬性來設定
  1. width:設定內容的寬度
  2. height:設定內容的高度

邊框

(border),邊框屬于盒子邊緣,邊框里面屬于盒子內部,出了邊框都是盒子的外部

  • 邊框的大小會影響到整個盒子的大小

要設定邊框,需要設定三個樣式:

  1. 邊框的寬度 border-width
  2. 邊框的顏色 border-color
  3. 邊框的樣式 border-style

border-width可以用來指定四個方向的邊框的寬度

  • 值的情況
個數表示位置
四個值上、右、下、左
三個值上,左右、下
兩個值上下、左右
一個值上下左右
  • 出了border-width還有一組border-xxx-width
  • xxx可以是top right bottom left用來單獨指定某個邊的寬度

border-color用來指定邊框的的顏色,同樣可以分別指定四個邊的邊框(規則和border-width一致)
border-color也可以忽略不寫,如果省略了則自動使用color的顏色值

border-style指定邊框的樣式

可選值表現結果
solid表示實線
dotted點狀虛線
dashed虛線
double雙線

border簡寫屬性,通過該屬性可以同時設定邊框所有的相關樣式,并且沒有順序要求
除了border以外還有四個border-xxx

  • border-top
  • border-right
  • border-bottom
  • border-left
  • border-style的默認值是none 表示沒有邊框
    代碼例子:
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box1 {
            background-color: yellowgreen;
            height: 200px;
            width: 200px;
            border-width: 30px;
            border-style: solid dashed dotted double;
            /* border-color: lightcoral; */
            /* border-top-color: lightcoral;
            border-left-color: lightskyblue;
            border-right-color: magenta;
            border-bottom-color: navajowhite; */
            border-color: olivedrab red pink purple;
        }
    </style>
</head>

<body>
    <div class="box1"></div>
</body>

顯示結果:
在這里插入圖片描述

盒模型、盒子模型、框模型(box model)

css將頁面的所有元素都是設定為了一個矩形的盒子
將元素設定為矩形的盒子后,對頁面的布局就是講不同盒子擺放到不同的位置
每一個盒子都是由以下幾個部分組成:
內容區(content)
內邊距(padding)
邊框(border)
外邊框(margin)

內邊距(padding)

內容區和邊框之間的距離是內邊距
一共有四個方向的內邊距:

  • padding-top
  • padding-right
  • padding-bottom
  • padding-left

內邊距的設定會影響到盒子內部的大小
背景顏色會延伸到內邊距上
一般盒子的可見框的大小,由內容區、內邊距、邊框共同決定,所以在計算盒子大小時,需要將這三個區域加到一起計算

外邊距(margin)

  • 外邊距不會影響盒子可見框的大小
  • 但是會影響盒子的位置
  • 一共有四個位置的外邊框:
可選值表現結果
margin-top上外邊距,設定一個正值,元素會向下移動
margin-right默認情況下設定margin-right不會產生任何效果
margin-bottom下外邊距,設定一個正值,其下邊的元素會向下移動
margin-left左外邊距,設定一個正值,元素會向右移動

margin也可以設定負值,如果是負值則元素會向相反的方向移動
元素在頁面中是按照自左向右的順序排列的,所以默認情況下如果我們設定的左和上外邊距則會移動元素自身,而設定下和右外邊距會移動其他元素
margin的簡寫屬性

  • margin可以同時設定四個方向的外邊距,用法和padding一樣
  • margin會影響到盒子世紀占用的空間
    盒子模型內外邊距代碼例子:
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box1 {
            height: 200px;
            width: 200px;
            background-color: #abc;
            border: 20px blueviolet solid;
            padding: 20px 50px;
            margin-top: 50px;
            margin-right: 50px;
            margin-bottom: 100px;
            margin-left: 200px;
        }
        
        .box2 {
            height: 200px;
            width: 200px;
            background-color: #ab0;
        }
        
        .box3 {
            height: 280px;
            width: 540px;
            background-color: #a0c;
        }
    </style>
</head>

<body>
    <div class="box1">
        <div class="box2"></div>
    </div>
    <div class="box3"></div>
</body>

</html>

</html>

</html>

在這里插入圖片描述

盒子模型水平方向的布局

一個元素在其父元素中,水平布局必須滿足以下的等式
margin-left+border-left+padding-left+width+padding-right+border-right+margin-right=其父元素內容區的寬度(必須滿足)
以上等式必須滿足,如果相加結果使等式不成立,則成為過渡約束,則等式會自動調整
調整的情況:

  • 如果這七個值中沒有為auto的情況,則瀏覽器會自動調整margin-right值以使等式滿足

這七個值中有三個值可以設定成auto

  • width
  • margin-left
  • margin-right

如果某個值為auto,則會自動調整為auto的那個值以便使等式成立

  • 如果將寬度和一個外邊距設定為auto,則寬度調到最大,設定auto的外邊距會自動為0
  • 如果將三個值都設定為auto,則外邊距都是0,寬度最大
  • 如果將兩個外邊距設定為auto,寬度固定值,則會將外邊距設定為相同的(所以我們經常利用這一特點來是一個元素在其父元素中水平居中)
    代碼例子:
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    .box1 {
        height: 200px;
        width: 600px;
        border: solid red 20px;
    }
    
    .box2 {
        height: 200px;
        width: auto;
        background-color: #abc;
        margin-left: 300px;
        margin-right: auto;
    }
</style>

<body>
    <div class="box1">
        <div class="box2"></div>

    </div>
</body>

</html>

把寬度和右外邊距設定為auto,當然你可以自己改
顯示結果:
把寬度和右外邊距設定為auto,當然你可以自己改

盒子模型垂直方向的布局

子元素是在父元素的內容區中排列的,如果子元素的大小超過了父元素,則子元素會從父元素中溢位,使用overflow屬性來設定父元素如何處理溢位的子元素

可選值顯示結果
visible默認值子元素會從父元素中溢位,父元素外部的位置顯示
hidden溢位內容將會被裁剪不會顯示
scroll生成兩個滾動條,通過滾動條來查看完整的內容
auto根據需要生成滾動條

補充:類似的屬性還有overflow-x 、overflow-y
例子代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box1 {
            height: 300px;
            width: 300px;
            background-color: #afd;
            overflow: auto;
        }
        
        .box2 {
            height: 600px;
            width: 600px;
            background-color: #afb;
        }
    </style>
</head>

<body>
    <div class="box1">
        <div class="box2"></div>
    </div>
</body>

</html>

結果顯示:
在這里插入圖片描述

盒子模型外邊距的折疊

垂直外邊距的重疊(折疊)
相鄰的垂直外邊距會發生重疊現象
兄弟元素

  • 兄弟元素間的相鄰垂直外邊距會取兩者之間的較大值(兩者都是正值)

特殊情況:

  • 如果相鄰的外邊距一正一負,則取兩者的和
  • 如果相鄰的外邊距都是負值,則取兩者中絕對值較大的
    兄弟之間的外邊距的重合,對于開發是有利的,所以我們不需要進行處理
    父子元素
  • 父子元素間相鄰邊距,子元素的會傳遞給父元素(上外邊距)
  • 父子外邊距的折疊會影響頁面的布局,必須要進行處理
    例子代碼:
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        /* .box1 {
            height: 100px;
            width: 200px;
            background-color: #bfa;
            padding-top: 100px;
        }
        
        .box2 {
            height: 100px;
            width: 100px;
            background-color: #abc;
        } */
        
        .box1 {
            height: 200px;
            width: 200px;
            background-color: #bfa;
            border: 1px solid #bfa;
        }
        
        .box2 {
            height: 100px;
            width: 100px;
            background-color: #abc;
            margin-top: 101px;
        }
    </style>
</head>

<body>
    <div class="box1">
        <div class="box2"></div>
    </div>
</body>

</html>

表現結果:
在這里插入圖片描述

行內元素的盒模型

行內元素的盒模型

  • 行內元素不支持設定寬度和高度
  • 行內元素可以設定padding,但是垂直方向padding不會影響頁面的布局
  • 行內元素可以設定border,垂直發布方向的border不會影響頁面的布局
  • 行內元素可以設定margin,垂直方向的margin不會影響布局

display用來設定元素顯示的型別

可選值顯示結果
inline將元素設定為行內元素
block將元素設定為塊元素
inline-block將元素設定為行內塊元素
table將元素設定為一個表格
none元素不在頁面中顯示

解釋:
行內塊:既可以設定寬度和高度又不會獨占一行
visibility用來設定元素的顯示狀態

可選值顯示結果
visible默認值,元素在頁面中正常顯示
hidden元素在頁面中隱藏不顯示

display屬性里面的none與visibility屬性里面的hidden之間的區別:
none值在網頁上不會把設定為該值的部分內容顯示,也不會給該部分內容留位置,而visibility屬性里的hidden會隱藏該部分內容,并且保留該部分內容的位置,
參考代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .sp {
            background-color: #bfa;
            /* padding: 10px; */
            margin: 50px;
        }
        
        .box1 {
            height: 100px;
            width: 100px;
            background-color: #abd;
            margin: 80px;
        }
        
        a {
            background-color: red;
            /* display: block; */
            display: inline-block;
            /* display: none; */
            height: 100px;
            width: 100px;
            /* visibility: hidden; */
        }
    </style>

</head>

<body>
    <a href="javascript:;">超鏈接</a><a href="javascript:;">超鏈接</a>
    <span class="sp">我是一個span</span>
    <span class="sp">我是一個span</span>

    <div class="box1"></div>
</body>

</html>

顯示結果:
在這里插入圖片描述

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/208237.html

標籤:其他

上一篇:還在一行行敲代碼嗎?一起自定義vscode快捷輸入吧!

下一篇:ES 6新特性(Day07)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more