理解CSS相對定位和固定定位

来源:http://www.cnblogs.com/xiaohuochai/archive/2016/03/26/5321487.html
-Advertisement-
Play Games

× 目錄 [1]相對定位 [2]固定定位 前面的話 一般地,說起定位元素是指position不為static的元素,包括relative、absolute和fixed。前面已經詳細介紹過absolute絕對定位的基礎和應用,這篇博客介紹和梳理相對定位relative和固定定位fixed的相關知識 相 ...


×
目錄
[1]相對定位 [2]固定定位

前面的話

  一般地,說起定位元素是指position不為static的元素,包括relative、absolute和fixed。前面已經詳細介紹過absolute絕對定位的基礎應用,這篇博客介紹和梳理相對定位relative和固定定位fixed的相關知識

 

相對定位

定義

  可能理解起來最簡單的定位機制就是相對定位了。採用這種機制時,通過使用偏移屬性移動定位元素。當元素相對定位時,它會從其正常位置移走,不過,原來所占的空間並不會因此消失。相對定位元素,會為其所有子元素建立一個新的包含塊。這個包含塊對應於該元素原本所在的位置

  [註意]如果相對定位元素遇到過度受限的問題,一個值會重置為另一個值的相反數。bottom總是等於-top,right總是等於-left

 

特性

【1】限制範圍

  一般地,給絕對定位元素限制範圍時,為其父級元素設置相對定位relative,因為相對定位元素不脫離文檔流

  [註意]相對定位元素可以限制絕對定位,但不能限制固定定位,因為固定定位是相對於視窗定位的

【2】提升層級

  當想要提升元素層級,又不想脫離文檔流時,使用相對定位是一個好主意

 

行內元素

  不同於絕對定位元素可以使元素具有塊級元素屬性,相對定位應用於inline元素後,由於無法改變其行內元素的屬性,不具備塊級元素屬性,無法設置寬高,其上下margin也依然存在問題

 

IE相容

  在IE6瀏覽器下,haslayout下的元素負margin超出父元素的部分會被隱藏掉。這個問題可以通過設置margin負值元素的position屬性值為relative來解決。

 

固定定位

  固定定位與絕對定位很類似,元素會完全從文檔流中去除,但固定元素的偏移是相對於視窗。

  [註意]IE7-瀏覽器不支持

 

特性

  固定定位與絕對定位的很多特性都類似,具有包裹性、破壞性及去浮動的特性,關於各瀏覽器中display屬性的bug、clip屬性的隱藏功能、靜態位置跳動以及overflow失效的表現都相同,在此就不再贅述。

 

全屏遮罩

  當頁面內容超出頁面容器大小出現滾動條時,此時使用absolute全屏遮罩會出現滾動條以外部分沒有遮住的情況。因為根元素html的父級是document,document的高度和可視區域一致,也就是與視窗一致,是不包括滾動條以外部分的。

  這時,只能使用fixed固定定位來實現全屏遮罩效果

.page{
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: pink;
    z-index: -1;
}    
.test{
    width: 2000px;
    height: 200px;
    background-color: lightblue;
}
<div class="page" id="page"></div>
<div class="test"></div>    
<button>absolute</button>
<button>fixed</button>
var btns = document.getElementsByTagName('button');
for(var i = 0; i < btns.length; i++){
    btns[i].onclick = function(){
        page.style.position = this.innerHTML;
    }
}

//分別點擊兩個按鈕,並拖動橫向滾動條查看效果


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

-Advertisement-
Play Games
更多相關文章
  • 題目: 計算字元串最後一個單詞的長度,單詞以空格隔開。 輸入: 一行字元串。 輸出: 整數N,最後一個單詞的長度。 例如: hello world 輸出: 5 思路: 考慮到最後一個單詞中可能含有空格,例如: “Hello world#" (#表示空格) int lenOfLastWord(cons... ...
  • 用PHPExcel做導出execl的時候發現在本地沒有問題,但是把網站傳到租用的伺服器的時候就報錯,具體如下: 代碼如下: ...
  • 在CRM(客戶關係管理)系統或者其他業務支撐型系統的開發過程中,最經常多變的就是複雜的業務規則。因為這些規則要迎合、順應市場的變化,如何能有效到做到業務規則和整體的系統支撐架構解耦分離,這個是開發過程中必須考慮的一個問題。每當客戶要求改變一個業務規則的時候,我們又如何能做到在最短的時間內完成需求的開 ...
  • 一、引言 這裡以電視遙控器的一個例子來引出橋接模式解決的問題,首先,我們每個牌子的電視機都有一個遙控器,此時我們能想到的一個設計是——把遙控器做為一個抽象類,抽象類中提供遙控器的所有實現,其他具體電視品牌的遙控器都繼承這個抽象類,具體設計類圖如下: 這樣的實現使得每部不同型號的電視都有自己遙控器實現 ...
  • 前言HTML 5如同一場革命,正在Web2.0後時代轟轟烈烈的進行著。HTML 5是什麼,無須我在這裡贅述了。對於HTML 5的革新,按我的理解,可以總結為語義明確的標簽體系、化繁為簡的富媒體支持、神奇的本地數據存儲技術、不需要插件的富動畫(canvas)、強大的API支持。總之,HTML 5讓人機 ...
  • 概述:本篇主要討論jquery.validate結合jquery.form實現對錶單的驗證和提交方案。 方式一:是通過jquery.validate的submitHandler選項,即當表單通過驗證時執行回調函數。在這個回調函數中通過jquery.form來提交表單; 方式二:是通過jquery.f ...
  • Js 程式採用Unicode字元集編碼的; Js語言嚴格區分大小寫(變數, 函數, 關鍵字,標識符) Js語言會忽略空格 換行 製表符 Js語句以 ;(分號) 結尾, 但是如果語句獨占一行是可以省略; 註:不是所有換行處都可以省略 ; 只有在缺少了分號,javascript無法正確解析代碼時, ja ...
  • 最近公司各種上線,所以回家略感疲憊就懶得寫了,這次我準備把剩下的所有方法全部分析完,可能篇幅過長...那麼廢話不多說讓我們進入正題。 沒看過前幾篇的可以猛戳這裡: underscore.js源碼解析(一) underscore.js源碼解析(二) underscore.js源碼解析(三) under ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...