添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

几种CSS渐变背景图片transtion动画方法

这篇文章发布于 2018年03月25日,星期日,21:19,归类于 CSS相关 。 阅读 46915 次, 今日 12 次 5 条评论

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

相关代码如下:

<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渐变感受过渡动画。

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

感谢阅读!

(本篇完)

分享 到:

张鑫旭 ,09年 华中科技大学 毕业,现 上海 ,就职于 阅文集团 ,专注 web前端 偏前领域,著有 《CSS世界》 《CSS选择器世界》 《CSS新世界》

邮箱: [email protected]

关注我: 微信 微博 掘金 知乎 头条 B站 Gitee

  • 前端原生API实现条形码二维码的JS解析识别 (113)
  • jQuery powerFloat万能浮动层下拉层插件 (110)
  • CSS sin()/cos()等数学三角函数简介与应用 (107)
  • 去除inline-block元素间间距的N种方法 (104)
  • AI代码辅助工具codeium和copilot在前端表现对比 (100)
  • IE6下png背景不透明问题的综合拓展 (80)
  • 以20像素为基准的CSS网页布局实践分享 (79)
  • 让IE6/IE7/IE8浏览器支持CSS3属性 (78)
  • 我使用CSS模拟个假的数字loading效果 (76)
  • 今年热议

  •