html怎么给图片加倒影,通过一张图教会你CSS3倒影的实现

本文介绍了如何使用CSS3的box-reflect属性为图片添加倒影效果,包括上下左右的方向设置、元素与倒影的间距以及使用渐变或图片作为遮罩。通过实例演示了从基本倒影到复杂遮罩的实现过程,展示了CSS3在倒影效果上的强大功能,尽管目前该属性主要兼容webkit内核浏览器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

本文主要给大家介绍了关于CSS3倒影实现的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

效果图如下:

a8547ace65fe1176c220d18f5145847a.png

示例图片

在CSS3之前,想要实现示例图片这样的一个倒影效果一般只能通过处理图片的方式,而CSS3问世之后,想要实现这样的效果变得非常简单,只需一个CSS3属性就可以轻松实现了。

这就是今天所要提到的box-reflect属性。

咱们先看看W3C给出的box-reflect语法:

box-reflect:none | ? ? (?代表可缺省,也就是后俩属性可有可无)

= above | below | left | right (分别代表:上 | 下 | 左 | 右)

= | (分别代表:固定值 | 百分比)

= none | | | | | (分别代表:没有遮罩图片 | 遮罩图片路径 | 线性渐变 | 径向渐变 | 重复线性渐变 | 重复径向渐变)

默认值:none

box-reflect可给两种属性值,一种是none,为默认值,也就是没有任何倒影效果,另一种才是我们今天所要讲的,它可以同时赋予三个属性值,它们依次代表倒影方向、元素与倒影之间的距离以及加在倒影上的遮罩图像,其中后两个属性值可以缺省,但如果存在,则必填。

说了那么多干巴巴的解释,还是联系一下示例应该更好理解些吧。

我们现在来一步步地实现文章开头示例图片的投影效果:

①只给一个属性值below。

< img class="img" src="imgs/cat.jpg" />

/*CSS代码*/

.img{ -webkit-box-reflect: below; box-reflect: below;}

实现效果:

a1a8c3177a1f4ee2ab6f6e19c53db9c7.png

②再加个5px的间距。

/*CSS代码*/

.img{ -webkit-box-reflect: below 5px; box-reflect: below 5px;}

实现效果:

0f39e4a419d63ff04afa61ec44fc6329.png

③最后加个图片遮罩吧。

/*CSS代码*/

.img{ -webkit-box-reflect: below 5px -webkit-linear-gradient(transparent 60%,rgba(0,0,0,.3));

box-reflect: below 5px linear-gradient(transparent 60%,rgba(0,0,0,.3));}

这里的图片遮罩没有用图片,而是用了CSS3中的linear-gradient属性值,它就是用于线性渐变,具体用法这里就不提了,可以直接看这里(https://www.jb51.net/css/369475.html),写得很详细。

实现效果:

4516c5ce432c77314a41ac92f9d7c724.png

这就是文章开头示例图片的最终效果。

接下来,再说说径向渐变创建图片遮罩和直接使用图片遮罩。

径向渐变的话其实跟线性渐变类似,只需要你掌握CSS3中基本的径向渐变方法,给个简单示例吧:

/*CSS代码*/

.img{ -webkit-box-reflect: left 0 -webkit-radial-gradient(#000 30%,transparent);

box-reflect: left 0 radial-gradient(#000 30%,transparent);}

实现效果:

5f7dd2fd9e44265135a5ae3110868eda.png

效果很棒!好像猫咪真的在照镜子一样~~

那如果直接使用图片遮罩呢?比如说我用这样一张图片作为遮罩:

46d80b968e554276d695b73fe366785a.png

/*CSS代码*/

.img{ -webkit-box-reflect: right 0 url(imgs/mask.png); box-reflect: right 0 url(imgs/mask.png);}

实现效果:

79142c16de3770834cf1d1b6da93a6b4.png

mask.png

可以看出,遮罩图片会完全拉伸填充倒影图片,并且效果是完全透明部分不会显示出来(其实CSS3渐变图片遮罩原理也跟这个是一样的)。

需要注意的是:以上讲的所有效果不仅仅可以用在图片上,用在其他元素上也是完全可以的,比如说文字。

兼容性:box-reflect虽然看起来效果很不错,但是遗憾的是,目前只有webkit内核浏览器兼容,不过移动端基本已经没有任何问题啦~~

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值