好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、background-image不支持 CSS 3 trans IT ion

background -i mage 不支持CSS3 transition ,而CSS3 gra die nt渐变作为背景图片存在的时候,下面的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; h ei ght: 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中的 Prop erties & am p; Values API 实现变化效果。

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

<div class="box"></div>
.box {     - -s tart-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教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-秀几种CSS背景渐变图片transtion过渡效果技巧 全部内容,希望文章能够帮你解决 html5教程-秀几种CSS背景渐变图片transtion过渡效果技巧 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-秀几种CSS背景渐变图片transtion过渡效果技巧的详细内容...

  阅读:25次