CSS徹底研究(3)-浮動,定位

来源:http://www.cnblogs.com/shouce/archive/2016/04/21/5415502.html
-Advertisement-
Play Games

CSS徹底研究(3)-浮動,定位 一 . 浮動float I . 定義及規則 float預設為none,對應標準流的情況。當float : left;時,元素就會向其父元素的左側靠緊,脫離標準流,同時寬度不再伸展至充滿父容器,而是根據自身內容來確定。 II . 演示規則 準備代碼 <html xml ...


CSS徹底研究(3)-浮動,定位

一 . 浮動float

I . 定義及規則

float預設為none,對應標準流的情況。當float : left;時,元素就會向其父元素的左側靠緊,脫離標準流,同時寬度不再伸展至充滿父容器,而是根據自身內容來確定。

II . 演示規則

準備代碼

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    <style>
        body
        {
            margin: 0;
            padding: 0;
        }

        #father
        {
            background-color: cyan;

            /*父級div 沒有定位 造成子div的margin-top傳遞給父級*/
            position: absolute;
        }

            #father *
            {
                margin: 10px;
                padding: 10px;
                border: 1px dashed red;
            }

        #son1
        {
        }

        #son2
        {
        }

        #son3
        {
        }
    </style>
</head>
<body>
    <div id="father">
        <div id="son1">#son1</div>
        <div id="son2">#son2</div>
        <div id="son3">#son3-son3son3son3</div>
        <p>
        這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字這是文字
        </p>
    </div>
</body>
</html>
  1. 中間給#father加上position:absolute,是為了消除未定位父div的margin-top傳遞問題,見http://blog.sina.com.cn/s/blog_6bec36f9010110w9.html
    顯示效果為
  2. 1,2的float分別為left right時,有

    可見1,2脫離標準流,標準流中的son3當他們不存在,於是son3代替原來son1的位置,而son1的左border、son2的右border與son3的左右border重合
  3. 當1,2,3全都float left時

    文字圍繞著float過的div
  4. 1,2左浮動,3右浮動,當視窗寬度減小時,3會被擠下來

    當3左浮動,2右浮動的時候,顯示為

    當瀏覽器視窗寬度減小時,猜猜誰會被擠下來,son2麽?

    答案還是son3,規則為 : 寫在html文件中後面的會被擠下來,在html文件中,son3在son2後面,因此總是son3先擠下來。
  5. 增加son1高度,son3擠下來時會卡在那裡
  6. 刪除盒子中的文字,3個子div全部左浮動
    顯示為

    父div中的三個子div全部脫離標準流了,父div就縮成一條線了,可以用clear來修正
    加一個margin-padding-border全為0,clear為both的空div,來撐大父div

III . clear清除浮動

如果前面有float:left的元素,他會影響下麵元素,如上例中的p,在p元素中寫clear : left即可消除前面左浮動元素對本元素的影響.同理clear:both是左右都清除.


二 . 定位position

position取值有static absolute relative fixed

1. static

這個是預設的,即標準流排下來,就是static定位方式.

2. fixed

在瀏覽器視窗中固定,什麼論壇中的[回到頂部]這種按鈕就是fixed做的
練習做個回到頂部玩玩

<div id="backToTop">
    回到頂部
</div>
#backToTop
{
    width: 100px;
    height: 50px;


    background-color: red;
    color: white;
    cursor: pointer;
    border-radius: 25px 0 0 25px;
    padding-left: 20px;


    text-align: center;
    line-height: 50px;

    position: fixed;
    bottom: 80px;
    right: 0;
}

顯示效果

3. relative相對定位

相對於自己的偏移,而且不脫離標準流,使用top/bottom left/right指定偏移量

4. absolute絕對定位

根據別的已定位元素進行定位,應用absolute規則的脫離標準流

  • 這個別的元素:
    離它最近的已定位的祖先元素 或者 瀏覽器視窗,當找不到前面的祖先元素時,就以後者瀏覽器視窗來定位.
  • 已經定位 : 是指position已經設置,而且不是static...即position值不為static就是已經定位的元素,未設置position或設置為static認為它沒有定位.

Trick
只設置 position : absolute,而不設置top/bottom/left/right值,那麼元素會保持在原地,但是已經脫離標準流.


三 . display

display取值有inline block none
設置為none,即可將其隱藏,像inline-block等新添加的,參考http://www.w3school.com.cn/cssref/pr_class_display.asp


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

-Advertisement-
Play Games
更多相關文章
  • Prim演算法 1.概覽 普里姆演算法(Prim演算法),圖論中的一種演算法,可在加權連通圖裡搜索最小生成樹。意即由此演算法搜索到的邊子集所構成的樹中,不但包括了連通圖裡的所有頂點(英語:Vertex (graph theory)),且其所有邊的權值之和亦為最小。該演算法於1930年由捷克數學家沃伊捷赫·亞爾尼 ...
  • 總是記不住API。昨晚寫的時候用到了這些,但是沒記住,於是就索性整理一下吧: python中對文件、文件夾(文件操作函數)的操作需要涉及到os模塊和shutil模塊。 得到當前工作目錄,即當前Python腳本工作的目錄路徑: os.getcwd() 返回指定目錄下的所有文件和目錄名:os.listd ...
  • Given two binary trees, write a function to check if they are equal or not. Two binary trees are considered equal if they are structurally identical a ...
  • 本文由@呆代待殆原創,轉載請註明出處。 工廠模式遵循的設計原則之一:找出代碼中常變化的部分,並把這一部分分離出來。(Dependency Inversion Principle) 工廠模式簡述 當我們需要在我們編寫的代碼裡面實例化(將類實例化,在java中就是用到new的時候)特定的類時,我們的代碼 ...
  • 具體排版 1、標題和標題類 <h1> ~<h6>和.h1~h6|副標題<small>和.small font-size margin-top margin-bottom h1 36px 20px 10px h2 30px 20px 10px h3 24px 20px 10px h4 18px 10p ...
  • 代碼如下: 1 var canvas = document.getElementById('my'), ctx = canvas.getContext('2d'); 2 setInterval(function(){ 3 ctx.clearRect(0,0,400,400); 4 ctx.save( ...
  • ...
  • 數組的常用方法總結 不改變原數組 1、Array.length; //獲取數組長度 2、Array.join(); //將數組以傳入的字元串進行拼接,返回拼接後的字元串,預設以“,”來拼接。 3、Array.concat(); //可以向數組末尾添加傳入的多個元素,或者是數組 4、Array.sli ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...