首页前端开发HTML秀几种CSS背景渐变图片transtion过渡效果技巧

秀几种CSS背景渐变图片transtion过渡效果技巧

时间2024-01-26 12:12:03发布访客分类HTML浏览497
导读:收集整理的这篇文章主要介绍了html5教程-秀几种CSS背景渐变图片transtion过渡效果技巧,觉得挺不错的,现在分享给大家,也给大家做个参考。小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。...
收集整理的这篇文章主要介绍了html5教程-秀几种CSS背景渐变图片transtion过渡效果技巧,觉得挺不错的,现在分享给大家,也给大家做个参考。小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。  

一、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):

.gradient{ max-width: 400px; height: 200px; background: linear-gradient(to right, olive, green, purple); background-size: 200%; transition: background-position .5s; } .gradient:hover { background-position: 100% 0; }

相关代码如下:

div class="box">
    /div>
.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前后效果对比:

相关代码如下:

div class="box">
    /div>
.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之后的效果:

相关代码如下:

div class="box">
    /div>
.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;
     }
    

五、日后补充新方法,结束语

补充于2018-11-25

还可以借助CSS houdini中的Properties & Values API实现变化效果。

CSS PRoPErties & Values API可以自定义CSS属性,例如,我们把渐变起止颜色定义为一个color> 类型的CSS属性,这样,渐变也能transition了,代码如下:

div class="box">
    /div>
.box {
         --start-stop: olive;
         --end-stop: green;
         background: linear-gradient(to right, VAR(--start-stop), var(--end-stop));
         transition: --start-stop .5s, --end-stop .5s;
 }
 .box:hover {
         --start-stop: green;
         --end-stop: purple;
 }

然后,最最关键的是就是借助CSS.registerProperty API把--start-stop--end-stop注册为合法的CSS属性,如下:

if (window.CSS) {
     CSS.registerProperty({
             name: '--start-stop',         syntax: 'color>
',         inherits: false,         initialValue: 'transparent'     }
    );
     CSS.registerProperty({
             name: '--end-stop',         syntax: 'color>
',         inherits: false,         initialValue: 'transparent'     }
    );
 }
    

然后渐变hover transition过渡效果就有了哈!

眼见为实,您可以狠狠地点击这里:CSS registerProperty渐变背景的transition过渡demo

可属性hover渐变感受过渡动画。


以上就是我所知道的几个方法,当然,肯定还有其他更好的实现,欢迎补充。

感谢阅读!

(本篇完)

觉得可用,就经常来吧! 欢迎评论哦! html5教程,巧夺天工,精雕玉琢。小宝典献丑了!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

APIClassCSScss3CSS属性divpost-format-galleryProp

若转载请注明出处: 秀几种CSS背景渐变图片transtion过渡效果技巧
本文地址: https://pptw.com/jishu/586744.html
小tips: 纯CSS显示JS/HTML等源代码行数 CSS3 :default伪类选择器简介

游客 回复需填写必要信息