CSS怎么实现背景渐变图片过渡效果
这篇文章主要介绍"CSS怎么实现背景渐变图片过渡效果"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"CSS怎么实现背景渐变图片过渡效果"文章能帮助大家解决问题。
一、background-image不支持CSS3 transition
background-image
不支持CSS3 transition
,而CSS3 gradient渐变作为背景图片存在的时候,下面的CSS设置是不会有过渡效果的。
.gradient { background-image: linear-gradient(to right, olive, green); transition: background-image 0.5s linear;}.gradient:hover { background-image: linear-gradient(to right, green, purple);}
鼠标hover会发现渐变的变化是很唐突的,一点过渡效果也没有。
下面问题来了,如果我们希望实现渐变hover时候有过渡变化的效果,该如何实现呢?我这里罗列的几种可行的方法。
二、借助background-position实现渐变过渡
background-image
虽然不支持CSS3 transition
过渡,但是background-position
支持啊,于是,通过控制背景位置,我们是可以实现渐变过渡效果的。
您可以狠狠地点击这里:借助background-position实现渐变过渡demo
实现效果如下(鼠标hover):
相关代码如下:
.box { max-width: 400px; height: 200px; background: linear-gradient(to right, olive, green, purple); background-size: 200%; transition: background-position .5s; }.box:hover { background-position: 100% 0; }
三、借助background-color实现渐变过渡
background-image
虽然不支持CSS3 transition
过渡,但是background-color
支持啊,于是,通过控制背景颜色,和一个颜色呈现技巧,我们也是可以实现渐变过渡效果的。
您可以狠狠地点击这里:background-color实现渐变hover过渡效果demo
鼠标hover前后效果对比:
相关代码如下:
.box { max-width: 400px; height: 200px; background: olive linear-gradient(to right, rgba(0,255,0,0), rgba(0,255,0,.5)); transition: background-color .5s; }.box:hover { background-color: purple; }
四、借助伪元素和opacity实现渐变过渡
借助伪元素创建变换后的渐变效果,通过改变覆盖的渐变的opacity透明度变化实现渐变过渡效果。
您可以狠狠地点击这里:CSS3 opacity实现渐变hover过渡效果demo
下图为hover之后的效果:
相关代码如下:
.box { max-width: 400px; height: 200px; background: linear-gradient(to right, olive, green); position: relative; z-index: 0; }.box::before { content: ''; position: absolute; left: 0; top: 0; right: 0; bottom: 0; background: linear-gradient(to right, green, purple); opacity: 0; transition: opacity .5s; z-index: -1;}.box:hover::before { opacity: 1; }
关于"CSS怎么实现背景渐变图片过渡效果"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。