html css inherit,CSS 继承 inherit属性的方法

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

0598e862cc6ddb80a82d36159a2068bc.png

制作如下的倒影效果:

e32c7ab529be7e68309fa09fee2e077f.png

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

法一:-webkit-box-reflect

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

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

d04716f99c0dfc7f478fc4a0c2a2c48a.png

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

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

div{

-webkit-box-reflect: below;

}

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);;

}

总结

到此这篇关于CSS 继承 inherit属性的方法的文章就介绍到这了,更多相关CSS 继承 inherit内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值