谈谈一些有趣的CSS题目(四)-- 从倒影提及,谈谈 CSS 继承 inherit

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

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

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

谈谈一些有趣的CSS题目(一)-- 左边竖条的实现方法github

谈谈一些有趣的CSS题目(二)-- 从条纹边框的实现谈盒子模型web

谈谈一些有趣的CSS题目(三)-- 层叠顺序与堆栈上下文知多少浏览器

全部题目汇总在个人 Github 。post

 

四、从倒影提及,谈谈 CSS 继承 inherit

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

制做以下的倒影效果:code

方法不少,可是咱们固然要寻找最快最便捷的方法,至少得是不管图片怎么变化,div 大小怎么变化,咱们都不用去改咱们的代码。orm

 

法一:-webkit-box-reflect

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

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

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

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

-webkit- 内核下查看Demo

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戳我

 

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

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

 

全部题目汇总在个人 Github ,发到博客但愿获得更多的交流。

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

相关文章
相关标签/搜索