javascript - jquery .delay() 不做事

标签 javascript jquery

您好,我已经制作了一个模态并为其添加了一个关闭按钮,因此当单击它时,它会向模态添加一个类,触发关闭模态动画,但后来我尝试再次删除该类,但它什么也没做

这是我的代码

$('.close').on('click', function(){
$(this)
  .parent().addClass("closing")
  .delay(3250)
  .queue(function() {
     $(this).parent().removeClass('closing');
     $(this).parent().removeClass('open');
     $(this).dequeue();
 });
});

我添加了一个控制台日志来查看 .delay 是否有效,但它似乎找不到正确的元素来从中删除类

最佳答案

由于链接,.queue() 内的此变量将引用 .close 元素的父元素。

$('.close').on('click', function () {
    $(this) // Initial element.
        .parent().addClass("closing") // this refers  to$(this).parent()
        .delay(3250)
        .queue(function () {
        $(this).parent().removeClass('closing'); // This refers to $(this).parent().parent()
        $(this).parent().removeClass('open');
        $(this).dequeue();
    });
});

解决方案

  $('.close').on('click', function() {

    $(this).parent().addClass("closing")
      .delay(3250)
      .queue(function() {
        $(this).removeClass('open closing').dequeue();
      });
  });
    .closing {
      background: red;
    }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div class="block">
  <p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est.
    Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus
    lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor,
    facilisis luctus, metus</p>
  <button class="close">Close</button>
</div>

关于javascript - jquery .delay() 不做事,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31490767/

相关文章:

javascript - 在 asp.net mvc3 中,如果大小超过 4mb,则无法上传文件

javascript - 偏移量不能将 div 返回到 0,0?

javascript - 如何在滚动事件发生之前为元素设置动画?

javascript - 如何将 $.ajax 对象传递给另一个函数?

javascript - iScroll:隐藏指示器时隐藏滚动条

javascript - 响应式菜单问题

jquery - 使用 html2canvas 更改背景无法正常工作

javascript - Extjs 布局扩展导致 ext-all.js 中出现错误

javascript - 使用和不使用 d3.json() 驱动 D3 图表

javascript - 谷歌时间表图表从错误的日期开始