菜单

从倒影说起

2019年12月8日 - 银河官方网站
从倒影说起

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

2016/09/29 · CSS ·
CSS

本文作者: 伯乐在线 –
chokcoco
。未经作者许可,禁止转载!
欢迎加入伯乐在线 专栏作者。

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

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

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

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

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

谈谈一些有趣的CSS题目(3):
层叠顺序与堆栈上下文知多少

所有题目汇总在我的 Github 。

谈谈一些有趣的CSS题目(四)– 从倒影说起,谈谈 CSS 继承 inherit,cssinherit

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

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

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

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

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

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

所有题目汇总在我的 Github 。

 

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

银河官方网站,给定一张有如下背景图的 div:

银河官方网站 1

制作如下的倒影效果:

银河官方网站 2

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

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

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

银河官方网站 3

制作如下的倒影效果:

银河官方网站 4

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

 

法一:-webkit-box-reflect

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

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

银河官方网站 5

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

CSS

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

1
2
3
div{
    -webkit-box-reflect: below;
}

-webkit- 内核下查看Demo

See the Pen
-webkit-box-reflect by
Chokcoco (@Chokcoco) on
CodePen.

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

 

法一:-webkit-box-reflect

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

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

银河官方网站 6

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

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 代码都无需改动:

CSS

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

1
2
3
4
5
6
7
8
9
10
div:before {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    bottom: -100%;
    background-image: inherit;
    transform: rotateX(180deg);;
}

Demo戳我

See the Pen image reflection by { background-image: inherit
} by Chokcoco
(@Chokcoco) on
CodePen.

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

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

 

所有题目汇总在我的 Github ,发到博客希望得到更多的交流。

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

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

打赏作者

法二: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 ,发到博客希望得到更多的交流。

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

从倒影说起,谈谈
CSS 继承 inherit,cssinherit 开本系列,讨论一些有趣的 CSS
题目,抛开实用性而言,一些题…

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

任选一种支付方式

银河官方网站 7
银河官方网站 8

2 赞 1 收藏
评论

关于作者:chokcoco

银河官方网站 9

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

个人主页 ·
我的文章 ·
63 ·
   

银河官方网站 10

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图