给定一张有以下背景图的 div:web
制做以下的倒影效果:浏览器
方法不少,可是咱们固然要寻找最快最便捷的方法,至少得是不管图片怎么变化,div
大小怎么变化,咱们都不用去改咱们的代码。bash
这是一个十分新的 CSS 属性,使用起来十分简单,能够从各个方向反射咱们内容。不过兼容性过于惨淡:spa
基本上是只有 -webkit- 内核的浏览器才支持。code
不过使用起来真的是方便,解题以下:orm
不过使用起来真的是方便,解题以下:cdn
div{
-webkit-box-reflect: below;
}
复制代码
box-reflect
有四个方向能够选,below | above | left | right
表明下上左右,更具体的能够看看 MDN 。blog
本题主要仍是为了介绍这种方法,兼容性好。继承
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);;
}
复制代码