html - 在悬停在两个不同元素上时应用相同的 CSS 动画

标签 html css

我正在尝试制作动画作为学习练习。当我将鼠标悬停在圆上时,我想对其应用动画,并显示 .hide 元素中的文本。但是当我将鼠标悬停在圆圈上然后将鼠标移到文本上时,动画停止了。

即使我将文本悬停在 .hide 元素中,是否有办法让两个动画都继续运行?我试图为带有动画的 .hide 类创建一个 :hover 子类,试图将动画添加到 .hide 类,并同时尝试了两者,但我无法弄清楚。

此外,悬停开始时弹出的那条小黑线很烦人,如果有人知道如何摆脱它的话。

.container {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.circle-icon {
  background: gray;
  border-radius: 50%;
  padding: 15px;
  color: white;
  transition: padding 1s;
  margin: 0px;
}

.circle-icon:hover {
  padding: 30px;
  animation-name: spin;
  animation-duration: 1s;
  animation-iteration-count: 2;
  animation-timing-function: ease-in-out;
  animation-direction: alternate;
}

.hide {
  position: relative;
  left: -15px;
  display: none;
  line-height: 40px;
  height: 40px;
  width: 100px;
  text-align: center;
  border-radius: 0 50px 50px 0;
  margin: 0px;
  vertical-align: middle;
  color: white;
  animation-name: slide;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-timing-function: ease-in-out;
  animation-direction: forward;
}

.circle-icon:hover + .hide {
  display: inline-block;
  background-color: gray;
  width: 100px;
}

@keyframes spin {
  0% {
    rotate: 0deg;
  }
  100% {
    rotate: 360deg;
  }
}

@keyframes slide {
  0% {
    width: 0px;
    font-size: 0%;
  }
  100% {
    width: 100px;
    font-size: 100%;
  }
}
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Home</title>
    <link rel="stylesheet" href="style.css" />
    <script
      src="https://kit.fontawesome.com/7dd2bd858f.js"
      crossorigin="anonymous"
    ></script>
  </head>
  <body>
    <div class="container">
      <a href="#">
        <i class="fas fa-home circle-icon"></i>
        <span class="hide">HOME</span>
      </a>
    </div>
  </body>
</html>

最佳答案

您需要进行一些更改,我已在示例后对每一项进行了解释,但总而言之:

你遇到问题的主要原因是因为你只是在 circle-icon 上悬停 - 这意味着当你将鼠标移开它时(即使它是相关的文本) 悬停效果结束。因此,您需要将鼠标悬停在整个 链接上,而不仅仅是圆圈上。

工作示例:

.container {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.circle-icon {
  background: gray;
  border-radius: 50%;
  padding: 15px;
  color: white;
  transition: padding 1s;
  margin: 0px;
}

a.icontextlink { text-decoration:none;}

.icontextlink:hover .circle-icon {
  padding: 30px;
  animation-name: spin;
  animation-duration: 1s;
  animation-iteration-count: 2;
  animation-timing-function: ease-in-out;
  animation-direction: alternate;
}

.hide {
  position: relative;
  left: -15px;
  display: none;
  line-height: 40px;
  height: 40px;
  width: 100px;
  text-align: center;
  border-radius: 0 50px 50px 0;
  margin: 0px;
  vertical-align: middle;
  color: white;
  animation-name: slide;
  animation-duration: 1s;
  animation-iteration-count: 1;
  animation-timing-function: ease-in-out;
  animation-direction: forward;
}

.icontextlink:hover .hide {
  display: inline-block;
  background-color: gray;
  width: 100px;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
     transform: rotate(360deg); 
  }
}

@keyframes slide {
  0% {
    width: 0px;
    font-size: 0%;
  }
  100% {
    width: 100px;
    font-size: 100%;
  }
}
<script
      src="https://kit.fontawesome.com/7dd2bd858f.js"
      crossorigin="anonymous"
    ></script>

    <div class="container">
      <a href="#" class="icontextlink">
        <i class="fas fa-home circle-icon"></i>
        <span class="hide">HOME</span>
      </a>
    </div>

使其工作的改变:

<强>1。向链接添加一个类,这样我们就可以将 CSS 应用于它,而不是容器中的所有 a 元素,例如

<a href="#" class="icontextlink">
    <i class="fas fa-home circle-icon"></i><span class="hide">HOME</span>
</a>

<强>2。悬停整个链接时将动画添加到圆圈。为此,我们将 CSS 选择器从 .circle-icon:hover 更改为 .icontextlink:hover .circle-icon,例如:

.icontextlink:hover .circle-icon { animation-name: spin; /* etc... */ }

<强>3。当整个链接悬停时显示 hide 类 - 这意味着即使您将鼠标从圆圈移到文本上,它仍然是同一链接的一部分,因此效果没有结束。所以我们将选择器从 .circle-icon:hover + .hide 更改为 .icontextlink:hover .hide:

.icontextlink:hover .hide {  display: inline-block; /* etc... */ }

<强>4。悬停时隐藏蓝线 - 您看到的蓝线是浏览器中链接的默认样式。我们可以把这个 使用 text-decoration:none; 关闭,例如

a.icontextlink { text-decoration:none;}

<强>5。修复旋转动画 仅供引用,您没有在问题中提及它,但旋转动画不起作用。这是因为您正在使用例如旋转:0deg;。正确的方法是 transform: rotate(0deg);:

@keyframes spin {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

关于html - 在悬停在两个不同元素上时应用相同的 CSS 动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64248798/

相关文章:

css - 如何为 JSTree 获取兼容 IE8 的 css 主题?

javascript - 在这样的页面之间移动的正确方法是什么?

html - 使div在固定侧边栏(css)内可滚动

html - 如何处理 optgroup 在不同浏览器中的不同行为?

html - 让我的 CSS 框看起来正确,百分比宽度和边距。

javascript - 使用 jquery 突出显示当前菜单项 asp.net

javascript - 使用 JavaScript 调整文本大小

html - 如何使背景图像适合屏幕?

javascript - 无法在 Internet Explorer 中显示这个简单的 .hide() 代码

Javascript 在 onReady 之后加载外部框架