停止css @keyframes动画

解决方法来源
display重绘异步事件

场景:在做一个基于Vue ElementUI后台系统页面loading的时候,遇到了给v-loading加动画,却会阻塞v-loading结束自动display: none的问题,导致必须等动画时长走完,蒙层才none,才可以点击页面。

机制:由于display:none会引起页面的重绘事件,所以它是一个异步的延时事件,所以浏览器其实会先解析animate的代码,然后再执行display:none。

代码如下,必须加入 animation: none !important 停止动画,否则会有‘阻塞’效果。还有一种暂停动画的方法,试过没起作用 animation-play-state: paused; 。

.el-loading-mask {
   
  background: rgba(255, 255, 255, .1);
  backdrop-filter: blur(3px);
  background-image: url("../assets/images/XOsX.gif");
  background-size: 80px 80px;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  animation: comeup 10s infinite; // 动画
  .el-loading-spinner {
   
    display: none !important
  }
}
.el-loading-fade-leave-active{
   
  animation: none !important; // 删除动画(解决动画时长阻塞display:none问题)
}
@keyframes comeup {
   
  0%{
   background-size: 80px 80px;}
  90%{
   background-size: 210px 210px;}
  100%{
   background-size: 220px 220px;}
}

相关推荐

  1. 停止css @keyframes动画

    2024-01-12 17:52:01       37 阅读
  2. android recyclerview 中的animation滚动中动画停止了?

    2024-01-12 17:52:01       31 阅读
  3. jenkins job无法停止

    2024-01-12 17:52:01       36 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-12 17:52:01       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-12 17:52:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-12 17:52:01       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-12 17:52:01       20 阅读

热门阅读

  1. ubuntu 22.04源码装ros1 noetic

    2024-01-12 17:52:01       42 阅读
  2. 2024年Ubuntu18.04执行do-release-upgrade报错的解决方案

    2024-01-12 17:52:01       34 阅读
  3. 一个算法带来的反思+Map复杂方法的使用总结

    2024-01-12 17:52:01       22 阅读
  4. 深入了解线程

    2024-01-12 17:52:01       32 阅读
  5. Linux部署WBO在线白板

    2024-01-12 17:52:01       38 阅读
  6. 图像数据集扩展

    2024-01-12 17:52:01       37 阅读
  7. xbox无法登录,没有反应的解决方法*

    2024-01-12 17:52:01       128 阅读
  8. Web 基尼系数的计算

    2024-01-12 17:52:01       29 阅读
  9. 获取时间进行格式化

    2024-01-12 17:52:01       33 阅读