CSS 之 margin知識點

来源:http://www.cnblogs.com/syomm/archive/2016/07/09/5656350.html
-Advertisement-
Play Games

1.margin的百分比值 普通元素的百分比maigin相對於容器元素的寬度(width) 進行計算的。 這裡我們在圖片外面設置一個寬高分別為800 * 600的容器。設置img{ margin: 10%; } 結果如下 結果margin值都是 800 * 10% = 80px; 所以這裡都是相對於 ...


1.margin的百分比值

  普通元素的百分比maigin相對於容器元素的寬度(width) 進行計算的。

  這裡我們在圖片外面設置一個寬高分別為800 * 600的容器。設置img{ margin: 10%; }

  結果如下

       

     結果margin值都是 800 * 10% = 80px; 所以這裡都是相對於容器的寬度計算的 容器的寬度計算 容器的寬度計算。說三遍

2.絕對定位的百分比maigin值

   

  相對於第一個定位的祖先元素的 width值計算的。就是 parent 的 width = 1000px. 所以 margin = 100px;

3.可以使用margin 實現 2 : 1 的自適應

  比如 有兩個容器

     

  這裡 box的高度沒有指定。 由於設置 margin 50% 。他的高度就是父容器的一半  所以高寬比就是 1 : 2;

  

4. margin 的重疊 為什麼重疊

  A) margin 重疊的兩個特性

     只會發生在block的水平元素上。 (不包括 float 和 absolute元素)

    不考慮 wirte-mode(就是書寫格式)  只發生在 垂直方向(margin-top margin-bottom)

  B) 發生的情況

    1> 相鄰的兄弟元素

    2> 父級的第一個 和 最後一個子元素

    3> 空的 block。 

例子一 相鄰的兄弟元素

       

    這裡就是兩個兄弟元素 。

   這裡的 兩個p 之間只有一個em 沒有兩個em。 因為第一個margin-bottom 和 第二個的 margin-top 發生了重疊。

  例子二 父元素和最後一個子元素 重疊

   

  按照常規理論 son 和 父元素的 father 之間會 留出 80px的 margin-top值。但是實際上沒有。son的背景元素沒有變化 沒有留出80px;

  這裡只是 給 父元素設置了 80px;

  

  父子 margin重疊的 條件

  

    那麼怎麼幹掉margin-top 重疊呢?

    只要不讓它滿足那些條件就可以了。

       父元素添加 overflow: hidden;  border-top  padding-top (在他們之間加個空格);

例子三 空block元素的 margin 重疊。

       

  

  註意 裡面沒有任何內容的空元素 。空元素髮生margin重疊的條件

  

 4 margin重疊的計算規則

  A) 正正取大值

  B) 正負值相加

  C) 負負取最負。

5. margin 重疊的意義

  A)  連續段落或列表之類 如果沒有margin重疊 收尾出現 1 : 2 就會顯得不協調

  B) web 中任何地方嵌套或直接放div 都不會影響原來的佈局

  C) 遺落的空的任意 多個p元素 不要影響原來閱讀的排版

 

實際應用

  製作列表 的時候控制每個列表的距離裡面的

  

  .list{

    margin-top : 15px;

    margin-bottom: 15px;

  }

  更具有健壯性 即使最後一個 移除了 亦不會影響佈局

 


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

-Advertisement-
Play Games
更多相關文章
  • 源碼: <input type="checkbox" id="cleckAll" />全選 <div class="list"> <input type="checkbox" />覆選一 <input type="checkbox" />覆選二 <input type="checkbox" />覆選 ...
  • Javascript小學生都知道了javascript中的函數調用時會 隱性的接收兩個附加的參數:this和arguments。參數this在javascript編程中占據中非常重要的地位,它的值取決於調用的模式。總的來說Javascript中函數一共有4中調用模式:方法調用模式、普通函數調用模式、 ...
  • 概述 上一篇我們介紹瞭如何將$.ajax和Vue.js結合在一起使用,並實現了一個簡單的跨域CURD示例。Vue.js是數據驅動的,這使得我們並不需要直接操作DOM,如果我們不需要使用jQuery的DOM選擇器,就沒有必要引入jQuery。vue-resource是Vue.js的一款插件,它可以通過... ...
  • 經過今天的討論, 我們組初步給出了設計方案。 安裝了一晚上的 mockupBuilder 終於繪製了幾份界面的原型圖, 這裡需要吐槽下 mockupBuilder, 這個軟體很好用, 不過網頁版和單機版提供的功能不太一樣, 感覺單機版更全一些, 但是缺點是無法保存。。。 首頁:(初步設想是類似網易雲 ...
  • 一、表單 <form id="" name="" method="post/get" action="負責處理的服務端"> id不可重覆;name可重覆;get提交有長度限制,並且編碼後的內容在地址欄可見,post提交無長度限制,且編碼後內容不可見。 </form> 1、文本輸入 文本框<input ...
  • JavaScript對象與繼承 JavaScript是我在C語言之後接觸的第二門編程語言,大一暑假的時候在圖書館找了一本中國人寫的 "JavaScript" 程式設計來看。那個時候在編程方面幾乎還是小白,再加上那本書根本沒有提JavaScript的編程機制,又有一些誤導性的話,一直以來對JavaSc ...
  • 所有的函數都具有call(),apply()和bind()方法。它們可以在執行方法的時候用一個值指向this,並改變面向對象的作用域。 apply方法: 以下的兩種表達式是等價的: func(arg1,arg2,arg3) func.apply(null,[arg1,arg2,arg3]) appl ...
  • 我們可以用Math.random()的方法輕鬆的生成一個隨機的數字,但是這個數字可能是重覆的。有時候,我們需要一個不重覆的隨機數,以下提供了一種高效率的方法。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...