用CSS3的box-reflect来制作倒影效果
兼容性
既然是CSS3的属性,我们要来看看兼容性
接下来,我们来了解box-reflect如何使用?
语法如下
-webkit-box-reflectnone | <direction> <offset>? <mask-box-image>? box-reflect:none | <direction> <offset>? <mask-box-image>?
属性说明
none此值为默认值,表示无倒影;
direction生成倒影的方向
above指定倒影在对象的上边 below指定倒影在对象的下边 left指定倒影在对象的左边 right指定倒影在对象的右边
offset图片与倒影间隔
length用长度值来定义倒影与对象之间的间隔。可以为负值 percentage用百分比来定义倒影与对象之间的间隔。可以为负值
mask-box-image用来设置倒影的遮罩效果;
值可以是
none无遮罩图像 url使用绝对或相对地址指定遮罩图像。 linear-gradient使用线性渐变创建遮罩图像。 radial-gradient使用径向(放射性)渐变创建遮罩图像。 repeating-linear-gradient使用重复的线性渐变创建背遮罩像。 repeating-radial-gradient使用重复的径向(放射性)渐变创建遮罩图像。
光是纸上谈兵可不行,我们还是要通过实例来看看效果。
倒影的方向
在这个例子中,我弄了三个img
<div class="box1"> <img src="http://7s1r1c.1.z0.glb.clouddn./t_sdfsdfs123.jpg" alt="" /> </div> <div class="box2"> <img src="http://7s1r1c.1.z0.glb.clouddn./t_sdfsdfs123.jpg" alt="" /> </div> <div class="box3"> <img src="http://7s1r1c.1.z0.glb.clouddn./t_sdfsdfs123.jpg" alt="" /> </div>
css如下
.box1,.box2,.box3{ width:120px; float:left; margin-right:180px; } img{ width:100%; } .box1 img{ -webkit-box-reflect:right; box-reflect:right; } .box2 img,.box3 img{ -webkit-box-reflect: above; box-reflect:above; } .box3{ padding-:200px; }
效果图如下
在这里有一个疑问,box2和box3中的图片都设置了box-reflect:above,都是在顶部生成投影,为什么box2看不到效果呢?原因就是我给box3设置了padding-:200px,而box2没有,初步估计是因为没有空间让其显示生成的倒影。
倒影与对象之间的距离
了解了生成倒影的方向后,我们来看第二个属性,还是看例子
依旧用三张图片,不过样式改变一下
.box1 img{ -webkit-box-reflect:below 30px; box-reflect:below 30px; } .box2 img{ -webkit-box-reflect:below -30px; box-reflect:below -30px; } .box3 img{ -webkit-box-reflect:below 5%; box-reflect:below 5%; }
效果图如下
接下来我们学习一个属性。
遮罩效果
(1)使用渐变给倒影添加遮罩效果
.box1 img{ -webkit-box-reflect:below 0 -webkit-linear-gradient(,rgba(250,250,250,0),rgba(250,250,250,.0) 30%,rgba(250,250,250,.3)); box-reflect:below 0 linear-gradient(,rgba(250,250,250,0),rgba(250,250,250,.0) 30%,rgba(250,250,250,.3)); }
效果如下
使用背景图给倒影添加遮罩效果
我们需要一张五角星的png图片
.box2 img{ -webkit-box-reflect:below 0 url(http://7s1r1c.1.z0.glb.clouddn./t_star.png); box-reflect:below 0 url(http://7s1r1c.1.z0.glb.clouddn./t_star.png); }
效果如下
好了,到这里,本文关于CSS3的box-reflect属性的语法和使用已经介绍完了。希望本文的内容对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。
长沙网站设计
- 如何进行东阳SEO关键词优化?
- 边坝哪有关键词排名优化:提升你的网站流量与
- 安国百度优化服务:提升您的在线可见性
- 阜康新手做SEO怎么做
- 山西seo网站排名关键词优化:提升您网站曝光率
- 临沂seo网站排名关键词优化:提高你的网站可见
- 广西SEO网站推广怎样付费比较合理
- 双辽SEO网站推广:提升你的网站可见性与流量
- 辽宁企业网站优化购买方式有哪些
- 提升宝清百度SEO排名的实用技巧与策略
- 静宁百度SEO排名:提升您网站曝光率的关键策略
- 彭州百度SEO排名的提升策略和实施指南
- 广南百度关键词SEO:提升网站排名的关键策略
- 辽宁关键词优化怎么做论坛营销
- 吉林百度seo排名如何做到让用户满意
- 内黄百度优化服务:提升在线可见性的关键