查看原文
其他

有趣的CSS题目(4): 从倒影说起,谈谈 CSS 继承 inherit

2016-10-17 前端大全

(点击上方公众号,可快速关注)


作者:伯乐在线专栏作者 - chokcoco

链接:http://web.jobbole.com/88213/

点击 → 了解如何加入专栏作者


开本系列,讨论一些有趣的 CSS 题目,抛开实用性而言,一些题目为了拓宽一下解决问题的思路,此外,涉及一些容易忽视的 CSS 细节。


解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的 CSS 属性,赶紧去补习一下吧。


不断更新,不断更新,不断更新,重要的事情说三遍。



所有题目汇总在我的 Github (https://github.com/chokcoco/iCSS/issues/1)。


4、从倒影说起,谈谈 CSS 继承 inherit


给定一张有如下背景图的 div:



制作如下的倒影效果:


方法很多,但是我们当然要寻找最快最便捷的方法,至少得是无论图片怎么变化,div 大小怎么变化,我们都不用去改我们的代码。


法一:-webkit-box-reflect


这是一个十分新的 CSS 属性,使用起来十分简单,可以从各个方向反射我们内容。不过兼容性过于惨淡:


基本上是只有 -webkit- 内核的浏览器才支持。



不过使用起来真的是方便,解题如下:


div{

    -webkit-box-reflect: below;

}


-webkit- 内核下查看Demo(http://codepen.io/Chokcoco/pen/ORbvxJ)


box-reflect 有四个方向可以选,below | above | left | right 代表下上左右,更具体的可以看看 MDN 。


法二:inherit,使用继承


本题主要还是为了介绍这种方法,兼容性好。


inherit 是啥,每个 CSS 属性定义的概述都指出了这个属性是默认继承的 (“Inherited: Yes”) 还是默认不继承的 (“Inherited: no”)。这决定了当你没有为元素的属性指定值时该如何计算值。


灵活使用 inherit 继承父值,可以解决许多看似复杂的问题。对于本题,我们对图片容器添加一个伪元素,使用 background-image:inherit 继承父值的背景图值,就可以做到无论图片如何变,我们的 CSS 代码都无需改动:


div:before {

    content: "";

    position: absolute;

    top: 100%;

    left: 0;

    right: 0;

    bottom: -100%;

    background-image: inherit;

    transform: rotateX(180deg);;

}


Demo戳我(https://codepen.io/Chokcoco/pen/dppARA)


我们使用伪元素 background-image: inherit; 继承父元素的背景图,再使用 transform 旋转容器达到反射的效果。


说到底,CSS 属性的取值就是由默认值(initial),继承(inherit)与加权系统构成的(其实还有 unset(未设置)、revert(还原)),厘清它们的关系及使用方法对熟练使用 CSS 大有裨益。

 

所有题目汇总在我的 Github(https://github.com/chokcoco/iCSS/issues/1) ,发到博客希望得到更多的交流。


到此本文结束,如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。



专栏作者简介 ( 点击 → 加入专栏作者 


chokcoco:经不住流年似水,逃不过此间少年。

打赏支持作者写出更多好文章,谢谢!



关注「前端大全」

看更多精选前端技术文章

↓↓↓

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存