首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在jQuery中触发伪元素关键帧动画

在jQuery中触发伪元素关键帧动画
EN

Stack Overflow用户
提问于 2021-12-16 05:47:11
回答 1查看 85关注 0票数 1

所以我想用jQuery在一个按钮中动画这个伪元素,但是它是一个在悬停时触发的伪元素动画。这是

演示

这是我的代码,它想要触发伪元素动画,但是点击它之后什么都不会发生。

代码语言:javascript
运行
复制
$('button').click(function() {
    $('.borders').toggleClass('s');
})

演示

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-16 16:36:01

在css选择器出错的地方,我更改了以下内容:

代码语言:javascript
运行
复制
.borders:before.s {
    animation: loading_s 1s forwards;
}

.borders:after.ss {
    animation: loading_ss 1s forwards;
}

通过:

代码语言:javascript
运行
复制
.borders.s:before {
  animation: loading_s 1s forwards;
}

.borders.ss:after {
  animation: loading_ss 1s forwards;
}

注意:您可以使用空格切换多个类。

代码语言:javascript
运行
复制
$('button').click(function() {
  $('.borders').toggleClass('s ss');
})
代码语言:javascript
运行
复制
button {
  position:absolute;
  left:10%;
  top:10px;
}

.borders {
  display: inline-block;
  padding: 4px;
}
.borders:after,
.borders:before {
  position: absolute;
  content: '';
  height: 0%;
  width: 0%;

}

@keyframes loading_s {
  100% {
    border-top: 2px solid black;
      border-left: 2px solid black;
      height: calc(100% - 12px);
    width: calc(100% - 12px);
  }
}
@keyframes loading_ss {
  100% {
    border-right: 2px solid black;
      border-bottom: 2px solid black;
      height: calc(100% - 12px);
    width: calc(100% - 12px);
  }
}

.borders:before {
  left: 10px;
  top: 10px;
  border-top: 2px solid transparent;
  border-left: 2px solid transparent;

}

.borders:after {
  bottom: 10px;
  right: 10px;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;

}

.borders.s:before {
  animation: loading_s 1s forwards;
}

.borders.ss:after {
  animation: loading_ss 1s forwards;
}
代码语言:javascript
运行
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<html>
<head>
    <title></title>
</head>
<body>
    <div class="borders">Hatdog</div>
    <button> Open </button>
</body>
</html>

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70374366

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档