CSS之Position詳解

来源:http://www.cnblogs.com/cby-love/archive/2016/04/08/5366274.html
-Advertisement-
Play Games

大家可以通過谷歌瀏覽器以網易網站做為範例,通過網站頂部的導航菜單欄來查看relative和aboulute的區別 CSS的很多其他屬性大多容易理解,比如字體,文本,背景等。有些CSS書籍也會對 這些簡單的屬性進行大張旗鼓的介紹,而偏偏忽略了對一些難纏的屬性講解,有避重就輕的嫌疑。CSS中主要難以理解 ...


大家可以通過谷歌瀏覽器以網易網站做為範例,通過網站頂部的導航菜單欄來查看relative和aboulute的區別

CSS的很多其他屬性大多容易理解,比如字體,文本,背景等。有些CSS書籍也會對 這些簡單的屬性進行大張旗鼓的介紹,而偏偏忽略了對一些難纏的屬性講解,有避重就輕的嫌疑。CSS中主要難以理解的屬性包括盒型結構,以及定位。正如 positioniseverything,本文將主要講述關於position的理解,力求讓您看完本文後對position有著最全面的認識。

position的四個屬性值:

  1. relative
  2. absolute
  3. fixed
  4. static

下麵分別講述這四個屬性。

<div id="parent">
     <div id="sub1">sub1</div>
     <div id="sub2">sub2</div>
</div>


1. relative

relative屬性相對比較簡單,我們要搞清它是相對哪個對象來進行偏移的。答案是它本身的位置。在上面的代碼中,sub1和sub2是同級關係,如果設定sub1一個relative屬性,比如設置如下CSS代碼:

#sub1
{
    position: relative;
    padding: 5px;
    top: 5px;
    left: 5px;
}


我們可以這樣理解,如果不設置relative屬性,sub1的位置按照正常的文檔流,它應該處於某個位置。但當設置sub1為的position為relative後,將根據top,right,bottom,left的值按照它理應所在的位置進行偏移,relative的“相對的”意思也正體現於此。

對於此,您只需要記住,sub1如果不設置relative時它應該在哪裡,一旦設置後就按照它理應在的位置進行偏移。

隨後的問題是,sub2的位置又在哪裡呢?答案是它原來在哪裡,現在就在哪裡,它的位置不會因為sub1增加了position的屬性而發生改變。

如果此時把sub2的position也設置為relative,會發生什麼現象?此時依然和sub1一樣,按照它原來應有的位置進行偏移。

註意relative的偏移是基於對象的margin的左上側的。

2. absolute

這個屬性總是有人給出誤導。說當position屬性設為absolute後,總是按照瀏覽器視窗來進行定位的,這其實是錯誤的。實際上,這是fixed屬性的特點。

當sub1的position設置為absolute後,其到底以誰為對象進行偏移呢?這裡分為兩種情況:

(1)當sub1的父對象(或曾祖父,只要是父級對象)parent也設置了position屬性,且position的屬性值為absolute或者relative或者fixed時,也就是說,不是預設值的情況,此時sub1按照這個parent來進行定位。

註意,對象雖然確定好了,但有些細節需要您的註意,那就是我們到底以parent的哪個定位點來進行定位呢?如果parent設定了 margin,border,padding等屬性,那麼這個定位點將忽略padding,將會從padding開始的地方(即只從padding的左上 角開始)進行定位,這與我們會想當然的以為會以margin的左上端開始定位的想法是不同的。

接下來的問題是,sub2的位置到哪裡去了呢?由於當position設置為absolute後,會導致sub1溢出正常的文檔流,就像它不屬於 parent一樣,它漂浮了起來,在DreamWeaver中把它稱為“層”,其實意思是一樣的。此時sub2將獲得sub1的位置,它的文檔流不再基於 sub1,而是直接從parent開始。

(2)如果sub1不存在一個有著position屬性的父對象,那麼那就會以body為定位對象,這個比較容易理解。

3. fixed

fixed是特殊的absolute,即fixed總是以瀏覽器的可視視窗進行定位。一定要註意,這個地方不是以html的body來定位。該屬性來設計網站頂部菜單隨著滾動條移動位置而固定住非常有用,如 網易網站頂部導航欄.

4. static

position的預設值,一般不設置position屬性時,會按照正常的文檔流進行排列


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

-Advertisement-
Play Games
更多相關文章
  • 遮罩彈窗的實現: <style> body{ height:100%; margin:0;} .shadow{ position:absolute; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.5; filte ...
  • 如果你打算建立自己的Web應用與AngularJS,那麼現在是時候開始了。如果這個想法嚇到你了,刪除所有的恐慌,從你的頭腦中有一些框架,AngularJS提供方便的支持。有一些預先的框架,使用框架可以如果你想建立一個Web應用程式的快速跑的是完美的你安裝的網路組件。這裡是一個名單,五個這樣的框架,可 ...
  • 關於浮動,最主要的就是解決浮動在IE6、7下要做的相容問題。例如:雙邊距bug,圖片下的空隙問題等等。後面要和定位帶來的相容問題一起總結一下好了~~~ 塊的特征 1、預設獨占一行 2、沒有寬度時,預設撐滿一排(即父元素有多寬它就是多寬) 3、支持所有css命令 行內元素的特征 1、同排可以繼續跟同類 ...
  • 最近做的一個h5活動因為嵌入視頻而發現了好多以前從未發現的問題,在測試的時候不同系統不同版本不同環境等多多少少都出現了些問題,搞得我也是焦頭爛額的,不過好在最終問題都解決了,自己也學到了好多東西,為了方便以後用到參考,所以就記下來咯。現在有一個感悟就是當問題來臨的時候不要覺得沮喪不要抱怨而要積極面對 ...
  • 一、Jquery常用的過濾選擇器如下所示: 1、:first,選取第一個元素,比如$("div:first")選取第一個div元素 2、:last,選取最後一個元素,比如$("div:last")選取最後一個div元素 3、:not(選擇器),選取不滿足“選擇器”條件的元素,比如$("div:not ...
  • 一些常用的表單驗證的代碼 註冊驗證: <script language="JavaScript" src="js/jquery-1.9.1.min.js" type="text/javascript"></script> //驗證表單 function vailForm(){ var form = ...
  • 隨著瀏覽器的升級,CSS3已經可以投入實際應用了。 <!-- /div --><!-- div id="more" class="asset-more" --> 但是,不同的瀏覽器有不同的CSS3實現,相容性是一個大問題。上周的YDN介紹了CSS3 Please網站,該網站總結了一些常用功能的寫法。 ...
  • 時間到了2015年6月18日,ES6正式發佈了,到了ES6,前面的各種模擬類寫法都可以丟掉了,它帶來了關鍵字 class,extends,super。 ES6的寫類方式 以上定義了一個類,constructor 是構造器,這點和 Java 不同,Java的構造器名和類名相同。 和 Java 多象啊, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...