淺談float浮動

来源:http://www.cnblogs.com/wangxiaosan/archive/2016/10/19/5978271.html
-Advertisement-
Play Games

float大概是css3以前網頁佈局里最常用的一個屬性了,經常看到一言不合就浮動的代碼,就一起來深入挖掘一下這個一半天使一半魔鬼的屬性吧。 本文是讀張鑫旭大神慕課網float視頻後的一些總結及一些拓展用法,視頻地址:http://www.imooc.com/learn/121。該視頻初讀很枯燥,認真 ...


float大概是css3以前網頁佈局里最常用的一個屬性了,經常看到一言不合就浮動的代碼,就一起來深入挖掘一下這個一半天使一半魔鬼的屬性吧。

本文是讀張鑫旭大神慕課網float視頻後的一些總結及一些拓展用法,視頻地址:http://www.imooc.com/learn/121。該視頻初讀很枯燥,認真讀後會發現更枯燥。。。。。。不過遇到坑之後再去讀就會發現良心視頻,字字珠璣。閑話不多說,現在開始:

1.float的起源

  浮動最初的設計是用來做文字的環繞效果的,這也是設計者想讓我們做的東西。

2.float的參數

  float屬性的參數取值有三個:

  left:表示元素浮動在左邊。

  right:表示元素浮動在右邊。

  none:對象不浮動,遵循標準文檔流。

3.效果展示(以float:left為例,float:right的情況只是位置的不同)

<style> 
div{
    height: 20px;
}
    .d1{
        width: 50px;
        background: hsl(100,50%,80%);
    }
    .d2{float: left;
        width: 100px;
        background: hsl(150,50%,80%);
    }
    .d3{
        width: 250px;
        height: 100px;
        background: hsl(10,50%,80%);
    }
    .d4{float: left;
        width: 300px;
        background: hsl(250,50%,80%);
    }
    span{
        margin-right: 3px; 
        border-right: solid 1px #ccc;
        background-color: hsl(60,50%,80%);
    }
    .s3{
        float:left;
    }
</style> 
<body> 
<div class="d1">div1</div>
<div class="d2">div2有float</div>
<div class="d3">div3</div>
<span class="s1">span1</span>
<span class="s2">span2</span>
<span class="s3">span3有float</span>
<div class="d4">div4有float</div>
<span class="s4">span4 </span>
</body> 

 

  當瀏覽器寬度不夠長時:

  當瀏覽器寬度足夠長時:

  我們可以得出以下幾個結論:

當浮動元素為塊狀元素時,他的下一個緊鄰元素(不浮動)是塊狀元素時會與該浮動元素髮生重疊,該浮動元素會在上方。如果下一個緊鄰元素為內聯元素時會緊跟該浮動元素。

當浮動元素為內聯元素時,他的下一個緊鄰元素(不浮動)是塊狀元素時不會移動,但寬度不夠也會發生重疊。如果下一個緊鄰元素為內聯元素時會緊跟該浮動元素。

4.浮動的破壞性

  設置了float的元素會脫離文檔流,會導致其父元素出現高度“坍塌”。

<div style="border:3px dashed #ddd">
    <p>我還沒設置float屬性</p>
</div>

<div style="border:3px dashed #ddd">
    <p style="float:left">我設置了float屬性</p>
</div>

5.浮動的包裹性

  這是沒有float的div

  這是個帶有float的div

6.浮動去空格

  這個已經在上面代碼和結論中中有所展示,簡單來說就是正常文檔流中兩個內聯元素之間以及上下會預設有一段縫隙,而浮動可以清除這個縫隙,讓兩個元素無縫結合,也會清除上下之間的縫隙。

7.清除浮動的影響

  7.1 使用clear屬性

  a.將<div style="clear:both;"></div>放到當作最後一個子標簽放到父標簽那兒,也是最簡單的清除浮動的方法,但是不推薦。

<div style="border:3px dashed #ddd">
    <p style="float:left">我設置了float屬性</p>
    <div style="clear:both"></div>
</div>

 

  

  b.after偽元素和zoom

  after,就是指標簽的最後一個子元素的後面。因此我們可以用CSS代碼生成一個具有clear屬性的元素

<style>
.mydiv{
        border:3px dashed #ddd
    }
    .mydiv:after{
        content: "";
        clear:both;
        display: block;    
    }
</style>
<body>
<div class="mydiv">
    <p style="float:left">我設置了float屬性</p>
</div>
</body>

 

 但是ie6/7無法識別偽元素after,就得用zoom方式,例:

.mydiv{
        border:3px dashed #ddd;
     zoom:1 }
  7.2 BFC
給父元素添加浮動,或者overflow:hidden,position:absolute等可以使元素BFC化的屬性,下節單獨探討BFC的生成條件和佈局規則,例:
<style> 
    .mydiv{
        border:3px dashed #ddd;
        overflow: hidden;
    }
</style> 
<body> 
<div class="mydiv">
    <p style="float:left">我設置了float屬性</p>
</div>
</body> 

關於float的佈局以及清除影響就先到這了,有遺漏和錯誤的地方歡迎指正,下節來一起看看BFC到底是什麼,他是如何佈局的,為什麼可以用來清除浮動。

 

 

 

 

 

  


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

-Advertisement-
Play Games
更多相關文章
  • 1. 正則表達式 是一個描述字元模式的對象. 1.創建方式 1) 正則表達式直接量 var pattern = /s$/; 2) RegExp()構造函數 var pattern = new RegExp("s$"); 2. 直接量字元 正則表達式中所有字母和數字都是按照字面含義進行匹配的。 字元 ...
  • 用了這麼久的Javascript,該總結下了!溫故而知新! var 聲明變數: javascript 是弱類型語言,因此無需為聲明對象明確類型聲明。 如:var test="字元串"; var num=123; var bool=true; 等價:var test="字元串", num=123, b ...
  • CSS的簡介 1、CSS概述及作用 CSS:Cascading Style Sheets)是層疊樣式表用來定義網頁的顯示效果。可以解決html代碼對樣式定義的重覆,提高了後期樣式代碼的可維護性,並增強了網頁的顯示效果功能。 作用:CSS將網頁內容和顯示樣式進行分離,提高了顯示功能。 2、 CSS和H ...
  • 優先順序: 外部樣式 < 內部樣式表 < 內聯樣式表; 優先順序,即:同名的選擇器右邊的會覆蓋左邊 1.內部樣式表 2.使用link標簽,在文檔中聲明使用外接資源,最常用的一種方式。 css外部樣式表指定編碼的@CHARSET="utf-8"; 需要放在第一行。 3.@方式,引入css,註意這個是非同步加 ...
  • AJAX簡介 (1)AJAX = 非同步 JavaScript 和 XML。 (2)AJAX 是一種用於創建快速動態網頁的技術。 (3)通過在後臺與伺服器進行少量數據交換,AJAX 可以使網頁實現非同步更新。這意味著可以在不重新載入整個網頁的情況下,對網頁的某部分進行更新。 (4)傳統的網頁(不使用 A ...
  • 在瀏覽器上輸入一個網址後,一個漂亮的頁面就呈現在我們眼前,中間發生了什麼了?對於一個普通用戶來講,也許不用思考這個問題,但要作為一個名前端開發人員或是想開發插件的同學來講,掌握瀏覽器的工作原理是非常有必要的! 瀏覽器主要功能 今天討論五種主流瀏覽器——IE、Firefox、Safari、Chrome ...
  • 本文介紹了絕對定位元素其定位對其寬度的影響情況,並且根據絕對定位元素的內容類型不同進行探討,給出了自己總結的規律,以解決元素寬度顯示不對的問題。 ...
  • require和 sea的源碼分析,我之前的博客有寫過, 今天我想分享的是一個很簡單的核心代碼(不帶註釋和空行大概60行), 沒有容錯判斷。 require.js require函數實現用一句話概括: 依次載入require的模塊,然後監測script的onload事件,判斷所有模塊載入成功,執行r ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...