我正在尝试在CSS上的缩略图上进行悬停过渡,以便在悬停时淡入背景渐变。过渡不起作用,但是如果我将其更改为rgba()值,则可以正常工作。不支持渐变吗?我也尝试过使用图像,它也不会转换图像。

我知道这是有可能的,就像在另一篇文章中有人做的那样,但我不知道该怎么做。任何帮助>以下是一些可使用的CSS:

#container div a {
  -webkit-transition: background 0.2s linear;
  -moz-transition: background 0.2s linear;
  -o-transition: background 0.2s linear;
  transition: background 0.2s linear;
  position: absolute;
  width: 200px;
  height: 150px;
  border: 1px #000 solid;
  margin: 30px;
  z-index: 2
}

#container div a:hover {
  background: -webkit-gradient(radial, 100 75, 100, 100 75, 0, from(rgba(0, 0, 0, .7)), to(rgba(0, 0, 0, .4)))
}

最佳答案

渐变尚不支持过渡(尽管当前规范说,它们应支持渐变,例如通过插值进行渐变过渡)。

如果要使用背景渐变的淡入效果,则必须在容器元素上设置不透明度,然后对不透明度进行“过渡”。

(有一些浏览器版本支持渐变过渡(例如IE10。我在2016年在IE中测试了渐变过渡,当时似乎可以使用,但我的测试代码不再起作用。)

更新:2018年10月
使用无前缀新语法的渐变过渡[例如radial-gradient(...)]现在确认可以再次在Microsoft Edge 17.17134上工作。我不知道何时添加。仍无法在最新的Firefox和Chrome / Windows 10上运行。

关于css - 在渐变背景中使用CSS3过渡,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45197846/

10-11 23:15
查看更多