【问题标题】:CSS transition delay in Google ChromeGoogle Chrome 中的 CSS 转换延迟
【发布时间】:2017-09-05 16:15:09
【问题描述】:

当您将鼠标悬停在一个圆圈上时,文本颜色应与旋转和背景颜色同时发生变化。

Firefox、IE、Edge 都按预期制作动画,但 Chrome 会延迟文本颜色的转换,就好像它在动画之前等待旋转完成,甚至在旋转和文本颜色更改之间留有间隙。

http://codepen.io/rachelreveley/pen/YNZawG

body {
  text-align: center;
  background-color: #122d40;
}
a {
  display: inline-block;
  width: 20rem;
  height: 20rem;
  margin: 1rem;
  transition: all 1s ease;
  position: relative;
  border-radius: 100%;
  text-decoration: none;
  color: #fff;
  overflow: hidden;
  background-color: #7fb400;
  transform: rotate(0deg);
}
a > span,
a span span {
  display: block;
  transition: inherit;
}
a span span:first-child {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 40%;
  text-transform: uppercase;
  font-size: 40px;
}
a span span:last-child {
  opacity: 0;
  padding: 2rem 3rem;
}
a:hover {
  background-color: #fff;
  color: #122d40;
  transform: rotate(360deg);
}
a:hover span span:first-child {
  opacity: 0;
}
a:hover span span:last-child {
  opacity: 1;
}
 
<a href=""><span><span>Space</span><span><h1>Lorem ipsum</h1> dolor sit amet, consectetur adipiscing elit. Ita nemo beato beatior. Si longus, levis; Utinam quidem dicerent alium alio beatiorem! Iam alium alio ruinas videres. Tamen a proposito, inquam, aberramus. </span> </span></a>
<a href=""><span><span>Speed</span><span><h1>Lorem ipsum</h1> dolor sit amet, consectetur adipiscing elit. Ita nemo beato beatior. Si longus, levis; Utinam quidem dicerent alium alio beatiorem! Iam alium alio ruinas videres. Tamen a proposito, inquam, aberramus. </span></span></a>
<a href=""><span><span>Support</span><span><h1>Lorem ipsum</h1> dolor sit amet, consectetur adipiscing elit. Ita nemo beato beatior. Si longus, levis; Utinam quidem dicerent alium alio beatiorem! Iam alium alio ruinas videres. Tamen a proposito, inquam, aberramus. </span></span></a>

【问题讨论】:

    标签: css google-chrome animation transition


    【解决方案1】:

    问题出在这里:

    a > span,
    a span span {
      transition: inherit;
    }
    

    这个过渡真的需要吗? 尝试删除该属性。

    body {
      text-align: center;
      background-color: #122d40;
    }
    a {
      display: inline-block;
      width: 20rem;
      height: 20rem;
      margin: 1rem;
      transition: all 1s ease;
      position: relative;
      border-radius: 100%;
      text-decoration: none;
      color: #fff;
      overflow: hidden;
      background-color: #7fb400;
      transform: rotate(0deg);
    }
    a > span,
    a span span {
      display: block;
    }
    a span span:first-child {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 40%;
      text-transform: uppercase;
      font-size: 40px;
    }
    a span span:last-child {
      opacity: 0;
      padding: 2rem 3rem;
    }
    a:hover {
      background-color: #fff;
      color: #122d40;
      transform: rotate(360deg);
    }
    a:hover span span:first-child {
      opacity: 0;
    }
    a:hover span span:last-child {
      opacity: 1;
    }
    <a href=""><span><span>Space</span><span><h1>Lorem ipsum</h1> dolor sit amet, consectetur adipiscing elit. Ita nemo beato beatior. Si longus, levis; Utinam quidem dicerent alium alio beatiorem! Iam alium alio ruinas videres. Tamen a proposito, inquam, aberramus. </span> </span></a>
    <a href=""><span><span>Speed</span><span><h1>Lorem ipsum</h1> dolor sit amet, consectetur adipiscing elit. Ita nemo beato beatior. Si longus, levis; Utinam quidem dicerent alium alio beatiorem! Iam alium alio ruinas videres. Tamen a proposito, inquam, aberramus. </span></span></a>
    <a href=""><span><span>Support</span><span><h1>Lorem ipsum</h1> dolor sit amet, consectetur adipiscing elit. Ita nemo beato beatior. Si longus, levis; Utinam quidem dicerent alium alio beatiorem! Iam alium alio ruinas videres. Tamen a proposito, inquam, aberramus. </span></span></a>

    【讨论】:

      猜你喜欢
      • 2015-04-18
      • 2015-12-05
      • 2015-07-01
      • 2015-09-01
      • 2016-02-28
      • 1970-01-01
      • 2017-05-16
      • 2014-07-10
      • 2014-10-02
      相关资源
      最近更新 更多