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

position:relative/absolute無法衝破的等級_經驗交流

May 16, 2016 pm 12:08 PM

註:本文實例在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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1422
52
Laravel 教程
1316
25
PHP教程
1267
29
C# 教程
1239
24
Google字體可變字體 Google字體可變字體 Apr 09, 2025 am 10:42 AM

我看到Google字體推出了新設計(Tweet)。與上一次大型重新設計相比,這感覺更加迭代。我幾乎無法分辨出區別

如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 Apr 11, 2025 am 11:29 AM

您是否曾經在項目上需要一個倒計時計時器?對於這樣的東西,可以自然訪問插件,但實際上更多

HTML數據屬性指南 HTML數據屬性指南 Apr 11, 2025 am 11:50 AM

您想了解的有關HTML,CSS和JavaScript中數據屬性的所有信息。

使Sass更快的概念證明 使Sass更快的概念證明 Apr 16, 2025 am 10:38 AM

在一個新項目開始時,Sass彙編發生在眼睛的眨眼中。感覺很棒,尤其是當它與browsersync配對時,它重新加載

我們如何創建一個在SVG中生成格子呢模式的靜態站點 我們如何創建一個在SVG中生成格子呢模式的靜態站點 Apr 09, 2025 am 11:29 AM

格子呢是一塊圖案布,通常與蘇格蘭有關,尤其是他們時尚的蘇格蘭語。在Tar​​tanify.com上,我們收集了5,000多個格子呢

如何在WordPress主題中構建VUE組件 如何在WordPress主題中構建VUE組件 Apr 11, 2025 am 11:03 AM

內聯式模板指令使我們能夠將豐富的VUE組件構建為對現有WordPress標記的逐步增強。

當您看上去時,CSS梯度變得更好 當您看上去時,CSS梯度變得更好 Apr 11, 2025 am 09:16 AM

我關注的一件事是Lea Verou' s conic-Gradient()Polyfill的功能列表是最後一項:

php是A-OK用於模板 php是A-OK用於模板 Apr 11, 2025 am 11:04 AM

PHP模板通常會因促進Subpar代碼而變得不良說唱,但這並不是這樣的情況。讓我們看一下PHP項目如何執行基本的

See all articles