首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何延迟fadeOut的函数?

如何延迟fadeOut的函数?
EN

Stack Overflow用户
提问于 2020-10-12 00:12:26
回答 1查看 31关注 0票数 0

我有这个函数:

代码语言:javascript
运行
复制
    $('#output').on('click', '[data-action="DELETE_ITEM"]', function () {
            var itemInfo = $(this.dataset)[0];
            var buttonOfProductHTML = document.querySelector(`[data-id='${itemInfo.id}']`);
            var buttonOfDeletion = document.querySelector('[data-action="DELETE_ITEM"]');
            $(buttonOfDeletion.parentElement.parentElement).fadeOut(1000);
            var itemIndex = $('[data-action="DELETE_ITEM"]').index(this);
            cart.splice(itemIndex, 1);
            sessionStorage['shopCart'] = JSON.stringify(cart);
            outputCart();
            handleCartButton(buttonOfProductHTML, 0);
        })

只有当我从cart.splice中删除代码时,我才能看到fadeOut效果,该代码从表(购物车)中删除一行。我猜删除的速度比效果快得多。我如何才能适当地延迟删除购物车项目以查看fadeOut效果?

谢谢,

EN

Stack Overflow用户

回答已采纳

发布于 2020-10-12 01:29:20

jQuery的fadeOut方法,接受回调函数作为第二个参数,这是可选的。回调函数在动画结束时执行。因此,您可以执行fadeOut并将所有代码放入回调函数中。:)

代码语言:javascript
运行
复制
$('#output').on('click', '[data-action="DELETE_ITEM"]', function() {
  var itemInfo = $(this.dataset)[0];
  var that = this;
  var buttonOfProductHTML = document.querySelector(`[data-id='${itemInfo.id}']`);
  var buttonOfDeletion = document.querySelector('[data-action="DELETE_ITEM"]');
  $(buttonOfDeletion.parentElement.parentElement).fadeOut(1000, () => {
    var itemIndex = $('[data-action="DELETE_ITEM"]').index(that);
    cart.splice(itemIndex, 1);
    sessionStorage['shopCart'] = JSON.stringify(cart);
    outputCart();
    handleCartButton(buttonOfProductHTML, 0);
  });
})
票数 0
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64306256

复制
相关文章

相似问题

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