background-image 不支持CSS3 transition ,而CSS3 gradient渐变作为背景存在的时候,下面的CSS设置是不会有过渡效果的。
gradient {
background-image: linear-gradient(to right, olive, green);
transition: background-image 05s linear;
}
gradient:hover {
background-image: linear-gradient(to right, green, purple);
}
鼠标hover会发现渐变的变化是很唐突的,一点过渡效果也没有。
下面问题来了,如果我们希望实现渐变hover时候有过渡变化的效果,该如何实现呢?我这里罗列的几种可行的方法。
二、借助background-position实现渐变过渡
background-image 虽然不支持CSS3 transition 过渡,但是 background-position 支持啊,于是,通过控制背景位置,我们是可以实现渐变过渡效果的。
实现效果如下(鼠标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 支持啊,于是,通过控制背景颜色,和一个颜色呈现技巧,我们也是可以实现渐变过渡效果的。
鼠标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透明度变化实现渐变过渡效果。
下图为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;
}
五、结束语
以上就是我所知道的几个方法,当然,肯定还有其他更好的实现,欢迎补充。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
html 的过渡效果
京东年货节特惠来袭!精华礼盒现购超值
京东
广告

《风尚坐火箭学习vue》-- 第十二章:Vue中的动画transition
174阅读·0评论·1点赞
2021年11月26日
image target behaviour 和image target的关系_CSS3中用background-image实现粒子动画效果
26阅读·0评论·0点赞
2020年11月20日
background-image的用法
138W阅读·2评论·33点赞
2016年9月9日
background-image 详解
10W阅读·1评论·7点赞
2014年11月17日
html文字过度效果,如何在上应用css3过渡属性?
510阅读·0评论·0点赞
2021年6月11日
HTML CSS 动画 实现过渡与变换(不超过边框范围局部放大)
1499阅读·1评论·4点赞
2021年11月25日
京东年货节,小年狂欢开启!酵素饮料现购超划算,速戳~

京东
广告
html 的过渡效果,3个CSS3过渡动画特效
1880阅读·0评论·1点赞
2021年6月11日需求是有一些动态内容折叠起来的,点击后d开
js定时器的动画过渡暂不考虑,于是就想到transition过渡
一开始就想着用trasition动画过渡就搞定啦,试了一下后,发现有问题
折叠的元素的高度height必须得设置一个值才可以有过渡的效果,要不就过渡不了
折中一下,就用js动态获取子元素的高度,然后给值到折叠的元素上实现过渡了
不过需要注意的是,内容的元素,虽然平常是不显示,但是还是暂据文本流的空间,所以缩起来后,要设置{visibility:hidden}
打开时再设置{visibility:visible}
用js触发css的过渡效果可以用impressjs实现。
以下例子实现了基于CSS3变化和过度效果:
$jmpress('template', 'arraytemplate', {
x: 100, y: 100, scale: 2,
children: [
{ x: 0, y: 150, scale: 02 },
{ x: 0, y: 450, scale: 03 }
]
});
支持现代浏览器Chrome,Safari和Firefox支持
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)