搜尋
首頁web前端前端問答css中什麼是絕對定位

css中什麼是絕對定位

Nov 02, 2021 pm 04:42 PM
css絕對定位

在css中,絕對定位是讓元素的位置與文件流程無關的定位方式。設定為絕對定位的元素框從文件流完全刪除,並相對於其包含區塊定位;預設情況下,絕對定位的位置是相對於瀏覽器而言,配合top、right、bottom、left進行定位。

css中什麼是絕對定位

本教學操作環境:windows7系統、CSS3&&HTML5版、Dell G3電腦。

在css中,絕對定位是讓元素的位置與文件流程無關的定位方式。

設定為絕對定位的元素框從文件流程完全刪除,並相對於其包含區塊定位,包含區塊可能是文件中的另一個元素或初始包含區塊。預設情況下,絕對定位的位置是相對於瀏覽器而言,會配合top、right、bottom、left進行定位。

元素原本在正常文件流程中所佔的空間會關閉,就好像該元素原來不存在一樣。元素定位後產生一個區塊級框,而不論原來它在正常流中產生何種類型的框。

下面我們來詳細了解絕對定位(absolute)。其實絕對定位absolute和浮動float有部分相似性;如果能理解浮動float,對理解絕對定位absolute會大有幫助。

先說absolute和float的相似處:包裹性高度欺騙

包裹性

##所謂一圖勝千言(唯一的差別是:下圖的p增加了absolute)

 css中什麼是絕對定位

<p   style="max-width:90%">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/1.jpg"  class="lazy"   / alt="css中什麼是絕對定位" >
</p>
<p style="border:4px solid red; position: absolute;">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"   / alt="css中什麼是絕對定位" >
</p>

一旦給元素加上absolute或float就相當於給元素加上了display:block;。什麼意思呢?例如內聯元素span預設寬度是自適應的,你給其加上width是不起作用的。要想width定寬,你需要將span設成display:block。但如果你給span加上absolute或float,那span的display屬性自動就變成block,就可以指定width了。因此如果看到CSS裡absolute/float和display:block同時出現,那display:block就是多餘的CSS程式碼。

高度欺騙

上例給圖片外層的p加上absolute,因此高度欺騙未能很好的體現出來,將absolute移到內部圖片上,效果就出來了:

 css中什麼是絕對定位

<p   style="max-width:90%">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/1.jpg"  class="lazy"   / alt="css中什麼是絕對定位" >
</p>
<p style="border:4px solid red;">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
</p>

如果你看過CSS浮動float詳解會發現效果是一樣的。但背後的原理其實是有區別的,並不完全相同。加點文字就看出來了:

css中什麼是絕對定位

<p   style="max-width:90%">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/1.jpg"  class="lazy"   / alt="css中什麼是絕對定位" >
</p>
<p style="border:4px solid red;">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
  我是一个绝对定位的absolute元素
</p>

從圖中明顯看出文字被圖片遮蓋了,這點和float不同。 float是欺騙父元素,讓其父元素誤以為其高度塌陷了,但float元素本身仍處於文檔流中,文字會環繞著float元素,不會被遮蔽。

但absolute其實已經不能算是欺騙父元素了,而是出現了

層級關係。如果處於正常的文檔流中的父元素算是凡人的話,那absolute已經得道成仙,用現在的話說已經不在一個次元上。從父元素的視點看,設成absolute的圖片已經完全消失不見了,因此從最左邊開始顯示文字。而absolute的層級高,所以圖片遮住了文字。

記得我剛開始接觸CSS尚處於戰鬥力為5的渣渣時,知道了absolute可以出現層級的概念,就誤以為已經徹底懂了,現在想想真是圖樣圖森破(當然這不是件壞事,每當你覺得以前的自己渣像塊豆腐渣時,就代表你進步了。反過來總說想當年自己如何,那表示你還在吃老本)。

有了上面的基礎後,你還需要了解absolute以下特性

    如何決定定位點
  • #和relative相愛相殺
  • 和z-index的關係
  • 減少重繪和回流的開銷

#如何決定定位點

一旦absolute分層後,第一個出現的問題就是讓瀏覽器在何處顯示該元素。普通文件流程裡的元素,瀏覽器可以根據其父子兄弟元素的大小和位置,計算出該元素的位置。但分層後怎麼辦?基本想法如下:

第一種情況:使用者只給元素指定了absolute,未指定left/top/right/bottom。此時absolute元素的左上角定位點位置就是該元素正常文件流裡的位置。如上圖例中,圖片熊貓是父親元素的第一個孩子,因此左上角定位點就是父元素的content的左上角。

如果將圖片熊貓和下面的文字順序改一下,讓其成為父元素的第二個孩子,一圖勝千言:

 css中什麼是絕對定位#

<p   style="max-width:90%">
  我是一个绝对定位的absolute元素
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
</p>

结论重复一遍:未指定left/top/right/bottom的absolute元素,其在所处层级中的定位点就是正常文档流中该元素的定位点。

第二种情况:用户给absolute元素指定了left/right,top/bottom

先简单点,让absolute元素没有position:static以外的父元素。此时absolute所处的层是铺满全屏的,即铺满body。会根据用户指定位置的在body上进行定位。

只指定left时,元素的左上角定位点的left值会变成用户指定值。但top值仍旧是该元素在正常文档流中的top值:

css中什麼是絕對定位 

<p   style="max-width:90%">
  我是一个绝对定位的absolute元素
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
</p>

只指定right时,元素的右上角定位点的right值会变成用户指定值。但top值仍旧是该元素在正常文档流中的top值:

css中什麼是絕對定位

<p   style="max-width:90%">
  我是一个绝对定位的absolute元素
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
</p>

只指定top时,元素的左上角定位点的top值会变成用户指定值。但left值仍旧是该元素在正常文档流中的left值:

css中什麼是絕對定位 

<p   style="max-width:90%">
  我是一个绝对定位的absolute元素
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
</p>

只指定bottom时,元素的左下角定位点的bottom值会变成用户指定值。但left值仍旧是该元素在正常文档流中的left值:

css中什麼是絕對定位 

<p   style="max-width:90%">
  我是一个绝对定位的absolute元素
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"    style="max-width:90%"  / alt="css中什麼是絕對定位" >
</p>

通过对left/top/right/bottom的组合设置,由于没有position:static以外的父元素,此时absolute元素可以去任意它想去的地方,天空才是它的极限。

和relative相爱相杀

通常我们对relative的认识是(好吧,我承认,这是我战5渣渣时的认识。如果你是弗利萨,可以鄙视这句话):relative主要用于限制absolute

上面已经说了,如果absolute元素没有position:static以外的父元素,那将相对body定位,天空才是它的极限。而一旦父元素被设为relative,那absolute子元素将相对于其父元素定位,就好像一只脚上被绑了绳子的鸟。

比如你要实现下图iOS里APP右上角的红色圈圈

css中什麼是絕對定位

通常的做法是将APP图片所处的p设成relative,然后红色圈圈设成absolute,再设top/right即可。这样无论用户怎么改变APP图片的位置,红色圈圈永远固定在右上角,例如:

css中什麼是絕對定位

.tipIcon {
  background-color: #f00;
  color: #fff;
  border-radius:50%;
  text-align: center;
  position: absolute;
  width: 20px;
  height: 20px;
  right:-10px;  //负值为自身体积的一半
  top:-10px;
}

<p style="display: inline-block;position:relative;">
  <img  src="/static/imghwm/default1.png"  data-src="img/25/2.jpg"  class="lazy"   / alt="css中什麼是絕對定位" >
  <span class="tipIcon">6</span>
</p>

这样做效果是OK的,兼容性也OK。但CSS的世界里要实现一个效果可以有很多种方式,具体选用哪个方案是见仁见智的。我比较看重的标准:一个是简洁,另一个是尽量让每个属性干其本职工作。

用这两个标准看待上述实现方法,应该是有改进的空间的。首先外层p多了relative未能简洁到极致。其次relative的本职工作是让元素在相对其正常文档流位置进行偏移,但父层p并不需要任何位置偏移,之所以设成relative唯一的目的是限制absolute子元素的定位点。因此在我看来这并没有让relative干其本职工作。好比小姐的本职工作是服务业,顺便陪客户聊聊天,但纯聊天聊完一个钟,恐怕会被投诉。

(学习视频分享:css视频教程

以上是css中什麼是絕對定位的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
React與後端框架:比較React與後端框架:比較Apr 13, 2025 am 12:06 AM

React是前端框架,用於構建用戶界面;後端框架用於構建服務器端應用程序。 React提供組件化和高效的UI更新,後端框架提供完整的後端服務解決方案。選擇技術棧時需考慮項目需求、團隊技能和可擴展性。

HTML和React:標記與組件之間的關係HTML和React:標記與組件之間的關係Apr 12, 2025 am 12:03 AM

HTML和React的關係是前端開發的核心,它們共同構建現代Web應用的用戶界面。 1)HTML定義內容結構和語義,React通過組件化構建動態界面。 2)React組件使用JSX語法嵌入HTML,實現智能渲染。 3)組件生命週期管理HTML渲染,根據狀態和屬性動態更新。 4)使用組件優化HTML結構,提高可維護性。 5)性能優化包括避免不必要渲染,使用key屬性,保持組件單一職責。

反應與前端:建立互動體驗反應與前端:建立互動體驗Apr 11, 2025 am 12:02 AM

React是構建交互式前端體驗的首選工具。 1)React通過組件化和虛擬DOM簡化UI開發。 2)組件分為函數組件和類組件,函數組件更簡潔,類組件提供更多生命週期方法。 3)React的工作原理依賴虛擬DOM和調和算法,提高性能。 4)狀態管理使用useState或this.state,生命週期方法如componentDidMount用於特定邏輯。 5)基本用法包括創建組件和管理狀態,高級用法涉及自定義鉤子和性能優化。 6)常見錯誤包括狀態更新不當和性能問題,調試技巧包括使用ReactDevTools和優

React和前端堆棧:工具和技術React和前端堆棧:工具和技術Apr 10, 2025 am 09:34 AM

React是一個用於構建用戶界面的JavaScript庫,其核心是組件化和狀態管理。 1)通過組件化和狀態管理簡化UI開發。 2)工作原理包括調和和渲染,優化可通過React.memo和useMemo實現。 3)基本用法是創建並渲染組件,高級用法包括使用Hooks和ContextAPI。 4)常見錯誤如狀態更新不當,可使用ReactDevTools調試。 5)性能優化包括使用React.memo、虛擬化列表和CodeSplitting,保持代碼可讀性和可維護性是最佳實踐。

React在HTML中的作用:增強用戶體驗React在HTML中的作用:增強用戶體驗Apr 09, 2025 am 12:11 AM

React通過JSX與HTML結合,提升用戶體驗。 1)JSX嵌入HTML,使開發更直觀。 2)虛擬DOM機制優化性能,減少DOM操作。 3)組件化管理UI,提高可維護性。 4)狀態管理和事件處理增強交互性。

REACT組件:在HTML中創建可重複使用的元素REACT組件:在HTML中創建可重複使用的元素Apr 08, 2025 pm 05:53 PM

React組件可以通過函數或類定義,封裝UI邏輯並通過props接受輸入數據。 1)定義組件:使用函數或類,返回React元素。 2)渲染組件:React調用render方法或執行函數組件。 3)復用組件:通過props傳遞數據,構建複雜UI。組件的生命週期方法允許在不同階段執行邏輯,提升開發效率和代碼可維護性。

反應嚴格模式目的反應嚴格模式目的Apr 02, 2025 pm 05:51 PM

React嚴格模式是一種開發工具,可通過激活其他檢查和警告來突出反應應用中的潛在問題。它有助於識別遺產代碼,不安全的生命週期和副作用,鼓勵現代反應實踐。

反應碎片使用反應碎片使用Apr 02, 2025 pm 05:50 PM

React片段允許將兒童分組而沒有額外的DOM節點,增強結構,性能和可訪問性。他們支持鑰匙以進行有效的列表渲染。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器