首頁 >web前端 >css教學 >使用CSS繼承inherit實作倒影的方法

使用CSS繼承inherit實作倒影的方法

高洛峰
高洛峰原創
2017-03-24 10:04:551551瀏覽

解題不考慮相容性,題目天馬行空,想到什麼說什麼,如果解題中有你感覺到生僻的CSS 屬性,趕緊去補習一下吧。

不斷更新,不斷更新,不斷更新,重要的事情說三遍。

4、從倒影說起,談談CSS 繼承# inherit

給定一張有以下背景圖的p:

使用CSS繼承inherit實作倒影的方法

製作如下的倒影效果:

使用CSS繼承inherit實作倒影的方法

方法很多,但我們當然要找最快、最方便的方法,至少要是無論圖片怎麼變化,p 大小怎麼變化,我們都不用去改我們的程式碼。

 

法一:-webkit-box-reflect

這是一個十分新的CSS 屬性,使用起來十分簡單,可以從各個方向反射我們內容。不過相容性太慘淡:

基本上是只有 -webkit- 核心的瀏覽器才支援。

使用CSS繼承inherit實作倒影的方法

不過使用起來真的很方便,解題如下:

p{
    -webkit-box-reflect: below;
}

- webkit- 內核下查看Demo

box-reflect 有四個方向可以選,below | above | <a href="http://www.php.cn/wiki/907.html" target="_blank">left</a># | <a href="http://www.php.cn/wiki/905.html" target="_blank">right</a> 代表下上左右,更具體的可以看看MDN 。

 

法二:inherit,使用繼承

本題主要還是為了介紹這個方法,相容性好。

inherit 是啥,每個CSS 屬性定義的概述都指出了這個屬性是預設繼承的("Inherited: Yes") 還是預設不繼承的("Inherited: no")。這決定了當你沒有為元素的屬性指定值時該如何計算值。

靈活使用 inherit 繼承父值,可以解決許多看似複雜的問題。這個問題,我們在圖片容器中加入一個偽元素,使用 <a href="http://www.php.cn/wiki/895.html" target="_blank">background-image</a>:inherit 繼承父值的背景圖值,就可以做到無論圖片如何改變,我們的CSS程式碼都不需要改動:

p:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    bottom: -100%;
    background-image: inherit;
    transform: rotateX(180deg);;
}

我們使用偽元素 background-image: inherit; 繼承父元素的背景圖,再使用transform 旋轉容器達到反射的效果。

說到底,CSS 屬性的取值就是由預設值(initial)繼承(inherit)加權系統構成的(其實還有 unset(未設定)revert(還原)),釐清它們的關係及使用方法對熟練使用CSS 大有裨益。

 

#

以上是使用CSS繼承inherit實作倒影的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn