解決CSS3的opacity屬性帶來的層疊順序問題

在最近的一個作品中,在使用 opacity 屬性來實現(xiàn)頁面整體透明的時候,發(fā)現(xiàn)了一個問題。如果兩個層發(fā)生了重疊,使用了 opacity 屬性并且屬性值小于1的層,會覆蓋掉后面的層。于是動手做了個實驗,來驗證 opacity 的層次。
網(wǎng)頁中的層疊規(guī)律是這樣的:如果兩個層都沒有定義 position 屬性為 absolute 或者 relative 屬性,哪個層的HTML代碼放在后面,哪個層就顯示在上面。如果指定了 position 屬性,并且設(shè)置了 z-index 屬性,誰的值大,誰就在上面。
發(fā)現(xiàn)問題
而對于沒有激活 z-index 的普通層來說,如果那個層使用了屬性值小于1的 opacity 屬性,哪個層就會顯示在上面。我們做一個Demo。代碼如下:
- <!DOCTYPE html>
- <html>
- <head>
- <title>帶有 opacity 的層疊問題</title>
- <style>
- html{padding:40px;}
- .dd{width:100px;height:100px;}
- a{background:red;}
- b{background:blue;margin-left:20px;margin-top:-80px;}
- c{background:green;margin-left:40px;margin-top:-80px;}
- </style>
- </head>
- <body>
- <div id=”a”></div>
- <div id=”b”></div>
- <div id=”c”></div>
- </body>
- </html>
保存為 html 文件打開之后,可以看到正常的次序
這時候,我們?yōu)?#a 加上屬性 opacity:0.9 神奇的事情發(fā)生了,它覆蓋了另外兩個層
只有當為另一個層(例如:#c)也設(shè)置一個小于1的opacity值(例如:0.8)之后,后面的 #c 才能安裝正常的規(guī)則覆蓋在 #a 上面。
這樣,增加了小于1的 opacity 屬性的層,升高了一個層次。至于里面的科學(xué)原理,我沒有想明白,或許也可能是一個小BUG。但是有時候這種情況是我們不希望發(fā)生的。
解決問題
那么如何來解決這個問題呢?前面也說過了,正常的情況下,指定了 position 并且指定了 z-index 值的層,擁有比普通層更高的層次,那么指定 opacity 的層和指定了 position 的層相比呢?我們對 #b 加上 position:relative 看看。這時候的樣式代碼如下:
- #a{background:red;opacity:0.9;}
- b{background:blue;margin-left:20px;margin-top:-80px;position:relative;}
- c{background:green;margin-left:40px;margin-top:-80px;opacity:0.8;}
保存刷新后,看到效果是這樣的:
也就是說,對層使用 position 屬性的 relative 之后,可以使其層次和 opacity 相同,這樣之后,按照正常的排序進行層疊顯示(在后面的實驗中,我對 absolute 屬性值也做了測試,結(jié)果和 relative 屬性值表現(xiàn)的相同)。當我們?nèi)∠?#c 的 opacity 屬性之后,我們可以看到,#c 被排在了最下面。
還沒有完,之前只是對 #b 激活了position:relative 屬性,還沒有使用 z-index。我們對 #b 進行了 z-index 的設(shè)置(例如:100),很顯然的,#b 成為了最頂層。
得出結(jié)論:
使用了position屬性值為 absolute、relative 的層,將會比普通層更高層次。使用了小于1的opacity屬性的層,也比普通層更高層次并且和指定 position 的層同層,但是不支持 z-index 屬性,所以指定 position 的層,可以使用 z-index 屬性,來覆蓋帶有小于1的 opacity 屬性的層。
相關(guān)文章
通過css3動畫和opacity透明度實現(xiàn)呼吸燈效果
這篇文章主要介紹了通過css3動畫和opacity透明度實現(xiàn)呼吸燈效果,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編2019-08-09詳解css透明度之rgba和opacity的區(qū)別及兼容
對于設(shè)置透明度,我們有兩個可以選的css3屬性:rgba 和 opacity。這篇文章主要介紹了詳解css透明度之rgba和opacity的區(qū)別及兼容,感興趣的可以一起跟隨小編來了解一下2019-01-10CSS中 opacity的設(shè)置影響了index(層數(shù))的改變的問題總結(jié)(推薦)
這篇文章主要介紹了CSS中 opacity的設(shè)置影響了index(層數(shù))的改變的問題,通過各種情況出現(xiàn)的問題進行了總結(jié)并附上了代碼,具體操作步驟大家可查看下文的詳細講解,感興趣2017-08-17css中使用rgba和opacity設(shè)置透明度的區(qū)別(附圖)
這篇文章主要介紹了css中使用rgba和opacity設(shè)置透明度的兩種方法,通過實例演示解釋了兩者之間的差別,需要的朋友可以參考下2017-08-14詳解CSS透明opacity和IE各版本透明度濾鏡filter的最準確用法
CSS3的透明度屬性opacity想必大家都已經(jīng)用的無處不在了。而對于不支持CSS3的瀏覽器如何進行透明處理,保持瀏覽器效果的一致,本篇文章主要介紹了詳解CSS透明opacity和IE各版2016-12-20詳解CSS3的opacity屬性設(shè)置透明效果的用法
這篇文章主要介紹了詳解CSS3的opacity屬性設(shè)置透明效果的用法,同時還講到了opacity透明度帶有的繼承性影響子集元素的問題,值得初學(xué)者注意,需要的朋友可以參考下2016-05-09- 用來設(shè)定元素透明度的 Opacity 是CSS 3里的一個屬性。當然現(xiàn)在還只有少部分瀏覽器支持,不過各個瀏覽器都有自己的私有屬性來支持,其中包括老版本的Mozilla和Safari2015-11-09
- 這篇文章主要介紹了CSS3中的opacity屬性使用教程,主要用來設(shè)置透明效果,需要的朋友可以參考下2015-08-19
- CSS 圖像透明度opacity想必大家并不陌生吧,使其可以讓圖片或者頁面擁有透明效果,下面為大家講解下CSS opacity的使用及其兼容性,感興趣的朋友可以參考下2013-09-08
CSS Alpha透明相關(guān)知識學(xué)習(xí)-CSS教程-網(wǎng)頁制作-網(wǎng)頁教學(xué)網(wǎng)
圖片的透明效果是網(wǎng)頁中需要用到的一種特殊形式,雖然不是非常的常用,但是遇到這樣的需求往往有點措手不及,在webjx.com的文章中雖然有這方面的CSS實例,但還沒有系統(tǒng)2008-10-17