首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多个丢弃事件后触发警报

多个丢弃事件后触发警报
EN

Stack Overflow用户
提问于 2012-10-16 19:06:55
回答 1查看 286关注 0票数 1

我得承认,我几乎是个菜鸟,但我一直在为这件事而挣扎。我必须在两个丢弃发生后触发if,现在它在加载时触发。我错过了什么?

代码语言:javascript
复制
$(function() {
    $( "#draggable" ).draggable({
        revert: "invalid",
        snap: "#droppable",
    });
    $( "#droppable" ).droppable({
        accept: "#draggable",
        drop: function() {
            $("#whistle").get(0).play();
            $(this).data(droppable)
        }
    });
    $( "#draggable2" ).draggable({
        revert: "invalid",
        snap: "#droppable",
    });
    $( "#droppable2" ).droppable({
        accept: "#draggable2",
        drop: function() {
            $("#whistle").get(0).play();
            $(this).data(droppable2)
        }
    });
    if ($.queue(2)) {
        $("#whistle2").get(0).play();
        alert ("done!")
    }
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-10-16 19:34:53

您可以使用两个$.Deferred及其promise-objects来触发您的处理程序:

代码语言:javascript
复制
$(function() {

    var dfd1 = $.Deferred();
    var dfd2 = $.Deferred();

    $( "#draggable" ).draggable({
        revert: "invalid",
        snap: "#droppable",
    });
    $( "#droppable" ).droppable({
        accept: "#draggable",
        drop: function() {
            $("#whistle").get(0).play();
            $(this).data(droppable);
            dfd1.resolve();
        }
    });
    $( "#draggable2" ).draggable({
        revert: "invalid",
        snap: "#droppable",
    });
    $( "#droppable2" ).droppable({
        accept: "#draggable2",
        drop: function() {
            $("#whistle").get(0).play();
            $(this).data(droppable2);
            dfd2.resolve();
        }
    });
    //this will trigger when both dfds have been resolved
    $.when(dfd1.promise(), dfd2.promise()).then(function(){
        $("#whistle2").get(0).play();
        alert ("done!")
    });
});

有关演示,请参阅this fiddle (单击这两个按钮即可看到神奇的发生!)并阅读有关$.Deferred$.when的信息

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

https://stackoverflow.com/questions/12913338

复制
相关文章

相似问题

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