margin塌陷與margin合併(margin),清除浮動

来源:https://www.cnblogs.com/LiAnChenglac/archive/2019/04/25/margin.html
-Advertisement-
Play Games

**1、margin塌陷**問題:垂直方向的父子關係的盒子使用不當會產生margin塌陷。給子級設置margin-top時,他不會相對父級一起動,只有他的margin超過父級的margin時,才會生效,但會帶著父級一起動(作者總結,官方定義自己查看)。如: ```<!DOCTYPE html><ht ...


**1、margin塌陷**
問題:垂直方向的父子關係的盒子使用不當會產生margin塌陷。給子級設置margin-top時,他不會相對父級一起動,只有他的margin超過父級的margin時,才會生效,但會帶著父級一起動(作者總結,官方定義自己查看)。
如:

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="parent" style="width:200px;height:200px; background-color:red;margin-top:20px;margin-left:20px">
<div class="son" style="width:100px;height:100px; background-color:yellow; margin-top:20px ">//20pxmargin-top
</div>
</div>
</body>
</html>
```

效果:

 


**解決方法:**
(1)給父級盒子加上邊框border:1px silod black;(改變結構了,不推薦使用)

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="parent" style="width:200px;height:200px;
background-color:red;margin-top:20px;margin-left:20px;border:1px solid black">
<div class="son" style="width:100px;height:100px; background-color:yellow; margin-top:20px ">
</div>
</div>
</body>
</html>
```

效果:

 


(2)觸發盒子的BFC模型(不懂就去百度吧)
如何觸發盒子的BFC呢?
1.Position:absolute;
2.display:inline-block;
3.float:left/right;
4.overflow:hiddle;
1.Position:absolute;給父級加上絕對定位,讓子級相對父級動。

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="parent" style="width:200px;height:200px;
background-color:red;margin-top:20px;margin-left:20px;position: absolute;">
<div class="son" style="width:100px;height:100px; background-color:yellow; margin-top:20px ">
</div>
</div>
</body>
</html>
```
效果:

 


2.display:inline-block;讓父級同時具有行級屬性和塊級屬性。

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="parent" style="width:200px;height:200px;
background-color:red;margin-top:20px;margin-left:20px;display: inline-block;">
<div class="son" style="width:100px;height:100px; background-color:yellow; margin-top:20px ">
</div>
</div>
</body>
</html>
```
效果:

 


3.float:left/right;讓父級產生浮動流

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="parent" style="width:200px;height:200px;
background-color:red;margin-top:20px;margin-left:20px; float:left;">
<div class="son" style="width:100px;height:100px; background-color:yellow; margin-top:20px ">
</div>
</div>
</body>
</html>
```
效果:

 


4.overflow:hiddle;溢出部分隱藏

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div class="parent" style="width:200px;height:200px;
background-color:red;margin-top:20px;margin-left:20px; overflow: hidden;">
<div class="son" style="width:100px;height:100px; background-color:yellow; margin-top:20px ">
</div>
</div>
</body>
</html>
```
效果:

 


**2、margin合併**
問題:
margin-left和margin-right區域不能共用。只會疊加。

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<span class="box1" style="background-color:yellow; margin-right:30px;">1</span>
<span class="box2" style="background-color:red; margin-left:50px;">2</span>
</body>
</html>
```
效果:

 


兩個兄弟結構垂直方向的margin共用。

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<span class="box1" style="background-color:yellow; margin-right:30px;">1</span>
<span class="box2" style="background-color:red; margin-left:50px;">2</span>
<div class="demo1" style="background-color:blue; margin-bottom:100px ;">3</div>
<div class="demo2" style="background-color:salmon; margin-top: 100px;">3</div>
</body>
</html>
```
效果:

 


解決垂直方向的margin合併問題也是觸動盒子的BFC。
解決方法如下:(嵌套盒子:然後:overflower:hidden;)
```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<span class="box1" style="background-color:yellow; margin-right:30px;">1</span>
<span class="box2" style="background-color:red; margin-left:50px;">2</span>
<div style="overflow:hidden;">
<div class="demo1" style="background-color:blue; margin-bottom:100px ;">3</div>
</div>
<div class="demo2" style="background-color:salmon; margin-top: 100px;">3</div>

</body>
</html>
```
效果:

 


**總結:**
在實際開發時不解決這個問題,比如說要解決垂直方面200px,為什麼不直接top200px呢,不用top100px,然後bottom100px。
**順帶說一下清除浮動的兩種兩種方法:**
(1)在有浮動的元素的後面加入一個標簽。
下麵我就簡單舉例了:
<div class = "clear"></div>
css中:
.clrar{clear:both;}
(2)使用偽類元素,找到需要清除的標簽,直接使用三件套:
.warpper::after{
content:"";
clrar:both;
display:block;
}

**想看更清除浮動更詳細的解答,請繼續關註作者的更新。**

如發現錯誤,請聯繫作者!!!!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 版權聲明:本文為HaiyuKing原創文章,轉載請註明出處! 前言 這個Demo只是記錄小米推送的集成,不能運行。 使用步驟 一、項目組織結構圖 註意事項: 1、 導入類文件後需要change包名以及重新import R文件路徑 2、 Values目錄下的文件(strings.xml、dimens. ...
  • 轉載請標明出處,維權必究:https://www.cnblogs.com/tangZH/p/10764726.html 因為要統計各個市場的下載量和其他數據,所以在打包的時候就需要針對每個渠道單獨打包,於是,多渠道打包自然就出現了。 不然一個一個打可真是要命。 1、在AndroidManifest. ...
  • 低版本的gradle裡面不會出現這個錯誤,高版本出現,不多說,看如何解決 在defaultConfig{}中添加:flavorDimensions "default" 保證所有的flavor 都屬於同一個維度 ...
  • 僅僅寫個xml就夠了,太簡單了 ...
  • MediaTek的MT8665是一款高度集成的LTE片上系統(SoC),它包含了先進的功能,例如LTE cat.4、Octa HMP核心在1.5GHz下工作、3D圖形(OpenGLES 3.0)、13MP攝像頭等。LPDDR3-640Mbps,全高清顯示和1080p視頻編解碼器.MT8665幫助設備 ...
  • 聯發科(p90)MT6779VWB晶元是一個集成了藍牙、fm、wlan和gps模塊的高度集成的基帶平臺,包括數據機和應用處理子系統。支持LTE/LTE-A和C2K智能手機應用程式。該晶元集成了兩個工作在2.2GHz的arm Cortex-A75核,6個運行到2.0GHz的ARM Cortex-A ...
  • 在瑞芯微電子第四屆“開發者之春”大會上,瑞芯微推出了新一代8nm旗艦處理器-RK3588 這個晶元將採用8nm 製程工藝、基於A76+A55 內核組合,具備4K UI性能、8K VPU,擁有NPU2.0 等。按照規劃2020年Q1量產。 據瑞芯微官方透露,RK3588採用的8nm製程將比前一代產品性 ...
  • 文章同步自http://javaexception.com/archives/34 如何給自己的app添加分享到有道雲筆記這樣的功能 問題: 在之前的一個開源筆記類項目Leanote中,有個用戶反饋想增加類似分享到有道雲筆記的功能,這樣就可以把自己小米便簽或者是其他記事本的內容分享到Leanote中 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...