理解浮動和position定位

来源:http://www.cnblogs.com/xiayi/archive/2016/04/06/5360405.html
-Advertisement-
Play Games

前言 為了更好理解浮動和position,建議先看看我寫的這篇文章《Html文檔流和文檔對象模型DOM理解》 正文 一、浮動 CSS設計float屬性的主要目的,是為了實現文本繞排圖片的效果。然而,這個屬性居然也成了創建多欄佈局最簡單的方式。 如何浮動一個元素?先設定其寬度width,再增加樣式規則 ...


前言

  為了更好理解浮動和position,建議先看看我寫的這篇文章《Html文檔流和文檔對象模型DOM理解》

正文

  一、浮動

  CSS設計float屬性的主要目的,是為了實現文本繞排圖片的效果。然而,這個屬性居然也成了創建多欄佈局最簡單的方式。

  如何浮動一個元素?先設定其寬度width,再增加樣式規則float:left/right。

  //註意:該浮動元素已從正常文檔流中刪除。浮動元素是被塊級元素忽略的元素,但是內聯元素知道它們在哪裡,內聯元素會留意浮動元素的邊界,而塊元素會正常流向頁面。

  提到浮動,就得提清除浮動clear。如下圖:

  

  因為塊級元素不知道左側浮動元素的存在(浮動元素不在文檔流中),所以塊級元素會鋪滿整個區域。可以用元素的CSS  clear屬性來提出請求:當元素流入頁面時,在這個元素的左邊、右邊或兩邊不允許有浮動內容。

  

  添加樣式clear:left;  這樣,塊級元素就會在浮動元素的下麵了。

  想瞭解更多浮動的知識,請看例子。《圍住浮動元素的三種方法》

   二、position

  position屬性有4個值:static、relative、absolute、fixed。

  (一)static

  HTML元素的預設值,即沒有定位,元素出現在正常的流中。靜態定位的元素不會受到top, bottom, left, right影響。

  (二)relative

  相對的是元素原來在文檔流中的位置(或者預設位置)。相對定位會讓元素正常地流入頁面,不過在頁面上顯示之前要進行偏移。

  //註意:這個元素原來占據的空間保留著,其他元素沒改變位置。相對定位元素經常被用來作為絕對定位元素的容器塊。

  (三)absolute

  絕對定位會把元素從文檔流中刪除,塊元素和內聯元素都不知道它的存在,絕對定位的元素的定位上下文是最近的已定位父元素,其預設的定位上下文<body>元素。

  //絕對定位元素的任何祖先元素都可以成為它的定位上下文,只要把相應祖先元素的position設定為relative/fixed即可。

  (四)fixed

  固定定位會把元素從文檔流中刪除塊元素和內聯元素都不知道它的存在,其定位上下文是視視窗。

  ps:relativeabsolutefixed有z-index屬性。

 

 

  

 


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

-Advertisement-
Play Games
更多相關文章
  • 解決方法有兩種: 一種是CSS,使用background-size:cover實現圖片的拉伸效果,但是IE8及以下版本不支持background-size,於是可以使用微軟的濾鏡效果,但是IE6不支持。 body{background:url(bg.jpg) center center;backgr ...
  • 今天偶然的發現有個網站轉載了我的插件,大概是1月份的時候吧,也就是我的LCalendar移動端日期選擇插件第一版開源到github上的時候,它便轉載了我的插件:http://www.grycheng.com/?p=2075大家可以點進去看一下,從文章中可以很明顯的看到轉載者已刪去了我的github地 ...
  • 《 網頁設計大師2 》超越第一代版本,提供更新更精美的網頁素材模板。全部由國際頂級設計師精選打造,完全展示走在潮流 之前的設計風格。是網頁設計師/UI交互界面設計師必備工具。 《 網頁設計大師2 》內含近2000個全新南韓網站PSD模板,每個模板包含1-2個首頁,3-5個子頁面PSD設計源文件。另有 ...
  • html代碼 CSS代碼 效果圖: 、 下麵介紹三種圍住浮動元素的方法。最終達成的效果都是: 方法一:為父元素添加 overflow:hidden //overflow:hidden聲明的真正用途是 1.防止包含元素被超大內容撐大。應用overflow:hidden之後,包含元素依然保持其特定的寬度 ...
  • Object 類型 中大多數的引用類型都值都是 類型的實例, 也是使用最多的一個類型,主要用來在程式中 存儲和傳輸數據 創建Object實例的兩種方式 1. 使用 操作符後跟Object構造函數 var user = new Object(); user.name = "MIKE"; user.ag ...
  • 即將畢業的軟體工程大學生一枚,秋季招聘應聘的是Android,今年來到公司實習,要求做前端開發,所以一切只有現學,現在根據視頻來學習,然後開這個博客記錄一下自己的學習過程,廢話不多說,開寫。 4月6日學到的知識點: 一:<!DOCTYPE HTML> ! 聲明,註意的意思; doc document ...
  • 實現目標:年月日三個select 輸入框,以及一個hidden的input,通過js獲取input的值,如果有值切是日期格式,年月日select為input中的時間。否則為空。年預設區間段為1900年到當今年份 本人使用了bootstrap,class請參照bootstrap的相關說明 下麵是htm ...
  • 項目地址 https://github.com/brinley/jSignature demo地址 http://willowsystems.github.io/jSignature/ /demo/ 初始化 getData 獲得canvas上的圖像數據,推薦使用 base30格式,相對於其他格式,存 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...