如何讓浮動的元素換行??css

来源:https://www.cnblogs.com/liveoutfun/archive/2018/07/30/9390198.html
-Advertisement-
Play Games

當你想要做成這種佈局效果的時候 紫色框裡面的內容那樣 它是一個列表 li元素是塊級元素 預設大小是父元素ul的寬 並且換行 如果li沒有背景的話那就不用管了 可是問題來了它不但有背景 而且是根據文字自適應的寬高 這就是inline-block類型的功能了 那麼想讓li是inline-block 設置 ...


當你想要做成這種佈局效果的時候

 

紫色框裡面的內容那樣

它是一個列表

li元素是塊級元素  預設大小是父元素ul的寬 並且換行

如果li沒有背景的話那就不用管了

可是問題來了它不但有背景 而且是根據文字自適應的寬高

這就是inline-block類型的功能了

那麼想讓li是inline-block 設置float  隱形改變

可是浮動的話 就不會換行了呀

問題又來了

沒事滴  給li folat:left  然後在clear:both 清除浮動不就好了

 

 

 

清除浮動一共四個屬性

clear:both|left|right|none;

我都測試了一下

首先box1 設置右clear:right 來達到不在同一行的目的

嗯 難道博主翻車了嗎  怎麼沒有達到理想的效果呢??

那麼我們把第二個元素box2設置clear:left; 看看結果

 

嗯 box1 box2 不在同一行了 實現了目的 

那為什麼box1設置clear:right 不好使呢

因為呢box1 只能通過改變自己的位置來讓自己右邊沒有浮動的元素

就像生活中 你改變不了別人 但是你可以改變自己

但是 box1就算改變了自己位置 box2 還會緊跟著box1的 因為浮動元素都是脫離文檔流的

並且脫離文檔流的理應去找脫離文檔流的元素  因為元素變成了特殊的inline-block類型

有寬高 並且不換行   inline 和 block 特征合體  很牛逼

這裡box1  就算清除右浮動  box2還是會跟著它 最終結果 box1 box2 box3 還是在一行

ps 可能你會想 那box1 跑到下一行  讓box2 box3 不動就好了 那不行的  清除浮動  不是float:none 都是浮動 並且 在html

中box1  box2 box3 是依次創建的  憑什麼你在我前面  你以為你是定位呢呢??瞎TM跑

 

但是box2清除左浮動  通過改變自身位置 換行

順序還是不變的 box1  box2  box 3  

box3跟著box2  驗證了前面說的

通過這次理解 對浮動又有了一個深刻的認知

 

 

所以你把需要換行的元素 都設置成clear:both

一點問題都沒有了

左邊不行 右邊    右邊也不行  那就靠下一個元素

對吧

 


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

-Advertisement-
Play Games
更多相關文章
  • [1]概述 [2]圖像資源 [3]預製資源 [4]圖集資源 [5]藝術數字資源 [6]字體資源 ...
  • 最近在開發Cesium的項目,每次一打開瀏覽器渲染3D 模型。風扇就狂飆起來,進任務管理器查看發現集顯使用率100%,獨顯使用率0%。使用的是集顯進行渲染。怪不得風扇會飆起來。既然知道問題所在,解決的辦法就很簡單了,將瀏覽器設置為使用獨顯就可以了。 具體設置方法可以去各種搜索引擎上搜索。百度經驗裡面 ...
  • 1 >new生成一個對象的過程 2>請簡單說明什麼是事件冒泡和事件捕獲以及事件委托 IE事件流叫作事件冒泡,即是事件開始有最具體的元素(文檔中嵌套最深的那個節點)接受,然後逐級向上傳播較為不具體的的節點 element(div)>element(body)>element(html)>Documen ...
  • 最近在使用這個插件的過程中發現一個bug: 不支持 含有小數的形式。 查看源碼後,修改了下其中的正則,使其支持小數形式(66.66px、.6px )。 作者的源碼最近一次更新都在兩年前,所以就簡單的記錄下 插件地址:https://www.npmjs.com/package/gulp-px2rem- ...
  • 同步請求:發送方發送數據包後,等待接收方發迴響應之後,才能發送下一個數據包的通信方式。 非同步請求:發送方發送數據包後,不用等待接收方發迴響應,就可以發送下一個數據包的通信方式。 同步通信:要求通信雙方在相同的時鐘頻率下,並且準確協調,是通過共用單個時鐘或定時脈衝源來保證雙方準確同步,效率高。 非同步通 ...
  • 1>對於有經驗得JavaScript開發者來說this也是一個非常難以理解的複雜機制,在此簡單分析一下 this的指向在函數的定義的時候是確定不了的,只有在函數執行的時候才能確定指向誰,實際上this最終指向的是調用他的那個對象(運行時) 2>搞清楚js裡面,函數的集中調用方法 總結:誰調用了這個函 ...
  • 不知道你們遇沒遇到過這個問題 就是當你給一個元素 添加touchstart touchmove touchend 的時候 比如box 並且子元素box有被父元素overflow隱藏的部分 父元素高度 500px 子元素高度 1500px 當你滑鼠沒有在子元素上點擊 移動 鬆開滑鼠 (向上拉的時候) ...
  • 最近幾年隨著h5的興起,複雜的h5動畫,甚至是交互動畫類型的產品不斷涌現,尤其在課件產品方面,很多公司都有相關需求,最近很多h5開發工程師想瞭解相關方面的技術。 針對h5,如果是簡單的動畫效果,可以考慮css3來實現,如果是較為複雜的動畫效果,比如有很多特效,動畫時長比較長,那麼就需要h5的動畫引擎 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...