CSS基礎知識之float

来源:http://www.cnblogs.com/shi0090/archive/2016/06/11/5574588.html
-Advertisement-
Play Games

前段時間寫過一篇 "CSS基礎知識之position" ,當時對float的理解不太準確,被慕課網多名讀者指出(原文已修正,如有誤導實在抱歉)。現對float進行更深入的學習,在此把學習心得分享給大家。 浮動的基礎知識 浮動有4個屬性:left(左浮動)、right(右浮動)、none(不浮動)、i ...


前段時間寫過一篇CSS基礎知識之position,當時對float的理解不太準確,被慕課網多名讀者指出(原文已修正,如有誤導實在抱歉)。現對float進行更深入的學習,在此把學習心得分享給大家。

浮動的基礎知識

  • 浮動有4個屬性:left(左浮動)、right(右浮動)、none(不浮動)、inherit(繼承)。
  • 浮動元素的包含塊是其最近的塊級祖先元素。
  • 浮動元素會左偏移(或右偏移),直到它的外邊界接觸到『包含塊的內邊界』或『另一個浮動元素的外邊界』。

  • 浮動元素脫離了標準文檔流,文字和行級元素會環繞該元素,塊級元素則不受影響。

  • 浮動一個非替換元素,必須為該元素聲明一個width,否則元素的寬度趨於0。

  • 浮動元素的margin(外邊距)不會與其他元素的margin合併。

浮動的深入研究

  • 浮動元素的頂邊不可以高於包含塊中先前產生的塊級元素或行級元素的頂。
  • 浮動元素之間不可重疊,如果水平方向沒有足夠的空間放置浮動元素,它將向下移動,直到有足夠的空間或沒有更多的浮動元素為止。
  • 浮動元素不能溢出包含塊的左、右、上邊界,僅可溢出下邊界。(浮動元素溢出下邊界時,部分瀏覽器會增加包含塊的高度,使浮動元素能夠包含在包含塊中,出現大片空白,導致瀏覽器相容性問題。)
  • 浮動元素設置負外邊距時,雖然浮動元素看起來溢出了包含塊,但實際並沒有違反上述規則。
  • 特殊情況,浮動元素比包含塊更寬時,浮動元素會在偏移的反方向溢出。

浮動的負作用

  • 背景不能顯示
  • 邊框不能撐開
  • margin padding 不能正確顯示

清除浮動的方法

.clear-float1{ content: “”; display: block; clear: both; }
/* 方法1,當父包含塊縮成一條時無效 */

.clear-float2{ overflow:hidden; width:100%; }
/* 方法2,overflow:hidden屬性相當於是讓父級緊貼內容,這樣即可緊貼其對象內內容,從而實現了清除浮動。 */

.clear-float3{ overflow: auto; zoom: 1; }
/* 方法3,zoom是在處理相容性問題,hidden和auto都能清除浮動,據說auto對seo更友好 */

擴展閱讀

歡迎大家來 石佳劼的博客 和我交流,在 這裡 留下您寶貴建議。


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

-Advertisement-
Play Games
更多相關文章
  • 1.什麼是服務註冊與發現 微服務將傳統的"巨石"應用拆分成一個一個的組件應用,每個組件應用提供特定的服務,可以是一個,也可以是多個,並且組件所含服務應該是可以動態擴展的,隨著時間推移、系統進化,可任意拆分、合併。 組件化應用和顆粒化的服務,遍佈在系統的各個角落,由不同的項目成員進行維護,微服務的核心... ...
  • 我從接觸ddd到學習cqrs有6年多了, 其中也遇到了不少疑問, 也向很多的前輩牛人請教得到了很多寶貴的意見和建議. 偶爾的機會看到國外有個站點專門羅列了ddd, cqrs和事件溯源的常見問題. 其中很多也是我一路過來都曾遇到過的. 這是原站地址http://www.cqrs.nu/Faq. 在EN ...
  • 之前同學做個購物商城秒殺活動需要計時器的功能,在用jquery提供的countdown插件時,一直報錯,貌似還需要依賴除jquery之外的其他插件,搞了半天也沒搞成功,就叫我幫忙寫個。然而我並沒有寫過插件,不過剛好趁這次端午好好地鍛煉一把吧,順便在這兒存個代碼,自己的思路不好,大神們請不要見笑哈.. ...
  • Bootstrap 教程 Bootstrap 簡介 Bootstrap 環境安裝 Bootstrap CSS 概覽 Bootstrap 網格系統 Bootstrap 排版 Bootstrap 代碼 Bootstrap 表格 Bootstrap 表單 Bootstrap 按鈕 Bootstrap 圖片 ...
  • 1,Vector3 類型變數存儲向量坐標值 Vector3.forward Vector3(0,0,1) Vector3.up Vector3(0,1,0) Vector3.right Vector3(1,0,0) Vector3.zero Vector3(0,0,0) Vector3.one Ve ...
  • none 此元素不會被顯示。 block 此元素將顯示為塊級元素,此元素前後會帶有換行符。 inline 預設。此元素會被顯示為內聯元素,元素前後沒有換行符。 inline-block 行內塊元素。(CSS2.1 新增的值) list-item 此元素會作為列表顯示。 run-in 此元素會根據上下 ...
  • jQuery 基金會剛剛發佈了該 JavaScript 框架的 3.0 版本,並且首次拋棄了對老舊的 IE 瀏覽器的支持。jQuery 3.0 的工作始於 2014 年 10 月,其最初目標是在 2.0 版本之上進行完善,並和遙遠的 1.0 版代碼說再見——因為要相容 IE 的緣故,其已經臃腫不堪。 ...
  • 1. 如何創建嵌套的過濾器 //允許你減少集合中的匹配元素的過濾器, //只剩下那些與給定的選擇器匹配的部分。在這種情況下, //查詢刪除了任何沒(:not)有(:has) //包含class為“selected”(.selected)的子節點。 .filter(":not(:has(.select ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...