搜尋
首頁web前端css教學position:relative/absolute無法衝破的等級_經驗交流

註:本文實例在IE5.x下可能會顯示不出來,請使用IE6、IE7、Firefox、Opera等瀏覽器來調試!
前段時間記得好像是誰在群組裡提出了一個實在是讓大家都覺得很不理解的一個問題: 

複製程式碼 程式碼如下:

      
  • 第一塊
  •   
  • 第二塊  
  • 第三塊
  •   
  • 第四塊
  •   
  • 第五塊
  •   
 

如果我我們設定LI為position:relative;設定span為position:absolute;那麼我們會發現無論SPAN的z-index值設定得再高都將永遠在後面父級的下面。
複製程式碼 程式碼如下:

*{margin:0; padding:0; list -style:none;}  
li {width:100px; height:100px; margin:0 5px 0 0; background:#000; float:left; position:relative; background:#000; float:left; position:relative; background:#000; float:left; position:relative; span {width:200px; height:200px; background:#c00; position:absolute; top:0; left:100px; z-index:1000;}  


[​​Ctrl A 全選注:如需引入外部Js需刷新才能執行]提示:您可以先修改部分程式碼再執行
試一下很容易發現我們的子級,z-index的值達到了1000的被設定了position:absolut;子級都被檔在了父級的下面。我想了很久,我覺得其根本問題是:設定同樣的position:relative/absolute;同級標籤之間的等級是無法用z-index超越的。我們上面的範例中的第一個LI的等級永遠都要小於後一個LI的等級,所以我們在LI裡的子級身上設定了position:absolute;,給了非常高的z-index值。
也許你會這樣來想:只要針對有span的LI設定position:relative;不就好了嗎?非常正確。當其它的LI都不設定position:relative;那麼我們需要的那個子層級就可以浮在所有的內容之上。但如果實際上,所有的LI中都要有span,而且屬性都需要一樣呢?當然我們不大會需要有這樣的效果。但是我們需要有這樣的效果:子級全部都是隱藏的,當有滑鼠反應時出現並且浮在所有的內容之上。我們要知道,這確實是件讓人頭痛的事,因為我們上面見識到了,子級在顯示的時候都被壓在了下一個父級標籤的下面。下面我們來實現這個滑鼠反應的定位效果:
複製程式碼 程式碼如下:

  

我們透過連結的滑鼠事件來完成這個顯示隱藏效果:
複製程式碼 程式碼如下:

*{ margin:0; padding:0; list-style:none;}  
li {height:100px; margin:0 5px 0 0; float:left; width:100px 0 0; float:left; width:100px); z-index:1; display:block; height:100px; width:100px;  background:#000;}  
li a:hover {background:#000000;} 
li a:hover {background:#000000;} 
li a:hover { BR>li a:hover span {display:block; background:#c00; width:200px; height:200px; position:absolute; top:0; left:100px; position:absolute; top:0; left:100px; position:absolute; top:0; left:100px; position:100 ; >

[​​Ctrl A 全選注:如需導入外部Js需刷新才能執行]
    提示:您可以先修改部分程式碼再運行
我們設定了a為位置:相對;這樣他的子級就會根據父級的坐標為坐標然後隱藏原點進行定位了。我們設定跨度的具體形狀以及定位屬性,然後重力了。再一個的α類:懸停使得span被啟動。我們看一下結果,我們會發現,所有的都應該在上面的現在全部在下面了。那我們怎麼解決這個問題呢,其實以CSS想要強行突破是不太可能的,所以我們反過來想,不能讓這個沒有被觸發的父級標籤沒有position:relative;屬性,而只是觸發的時候繼承這個父級賦上這樣的值?其實想到這裡基本上已經可以解決所有的問題了:
複製程式碼程式碼如下:

*{margin:0;填充:0;列表樣式:無;}  
li {高度:100px;邊距:0 5px 0 0;向左飄浮;寬度:100px;}  
li a {display:block;高度:100px;寬度:100px;背景:#000;}  
li a:hover {position:relative; z 索引:1; }  
li span {display:none;}  
li a:hover span {display:block;寬度:200px;高度:200px;背景:#c00;位置:絕對;頂部:0;左:100px; z 索引:1000; }  


[​​Ctrl A 全選注:如需引入外部Js需刷新才能執行]
    提示:您可以先修改部分程式碼再運行
我們只針對a:hover來設定其屬性為position:relative;就可以了,這樣只有在滑鼠觸發的時候A才會被賦於一個相對定位的屬性。這樣就完成可以解決被其他父級標籤所擋的尷尬了。BR> 當然如果不介意IE6或IE5.X這樣的瀏覽器 我們還可以把程式碼再做簡化:
複製程式碼程式碼如下:

      
  • 第一塊
  •   
  • 第二塊
  •   
  • 第三塊
  •   
  • 第四塊
  •   
  • 第五塊
  •   
  

CSS可以改成這樣:
複製程式碼 代碼如下:

*{margin:0; padding:0; list-style:none;}  
li {height:100px; margin:0 5px 0 0; float:left; width:100px; background:#000;}  
li:h {position:relative;#000;}  
li:h {position:relative;#000;}  
li:h {position:relative; span {display:none;}  
li:hover span {display:block; width:200px; height:200px; background:#c00; position:absolute; top:0 }  


[​​Ctrl A 全選注:如需引入外部Js需刷新才能執行]
    提示:您可以先修改部分程式碼再執行
原始閱讀:
http://andymao.com/andy/post/67.html
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
揭開屏幕讀取器的神秘面紗:可訪問的表格和最佳實踐揭開屏幕讀取器的神秘面紗:可訪問的表格和最佳實踐Mar 08, 2025 am 09:45 AM

這是我們在形式可訪問性上進行的小型系列中的第三篇文章。如果您錯過了第二篇文章,請查看“以:focus-visible的管理用戶焦點”。在

將框陰影添加到WordPress塊和元素將框陰影添加到WordPress塊和元素Mar 09, 2025 pm 12:53 PM

CSS盒子陰影和輪廓屬性獲得了主題。讓我們查看一些在真實主題中起作用的示例,以及我們必須將這些樣式應用於WordPress塊和元素的選項。

使用智能表單框架創建JavaScript聯繫表格使用智能表單框架創建JavaScript聯繫表格Mar 07, 2025 am 11:33 AM

本教程演示了使用智能表單框架創建外觀專業的JavaScript表單(注意:不再可用)。 儘管框架本身不可用,但原理和技術仍然與其他形式的建築商相關。

使用GraphQL緩存使用GraphQL緩存Mar 19, 2025 am 09:36 AM

如果您最近開始使用GraphQL或審查了其優點和缺點,那麼您毫無疑問聽到了諸如“ GraphQl不支持緩存”或

使您的第一個自定義苗條過渡使您的第一個自定義苗條過渡Mar 15, 2025 am 11:08 AM

Svelte Transition API提供了一種使組件輸入或離開文檔(包括自定義Svelte Transitions)時動畫組件的方法。

比較5個最佳的PHP形式構建器(和3個免費腳本)比較5個最佳的PHP形式構建器(和3個免費腳本)Mar 04, 2025 am 10:22 AM

本文探討了Envato Market上可用的PHP表單構建器腳本,比較了其功能,靈活性和設計。 在研究特定選項之前,讓我們了解PHP形式構建器是什麼以及為什麼要使用一個。 PHP形式

展示,不要說展示,不要說Mar 16, 2025 am 11:49 AM

您花多少時間為網站設計內容演示文稿?當您撰寫新的博客文章或創建新頁面時,您是在考慮

NPM命令是什麼?NPM命令是什麼?Mar 15, 2025 am 11:36 AM

NPM命令為您運行各種任務,無論是一次性或連續運行的過程,例如啟動服務器或編譯代碼。

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.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境