javascript - 不是作为 jQuery Deferred 执行的异步函数

标签 javascript jquery jquery-deferred deferred

假设我想以同步方式处理一些任务,所以我有这个功能:

function executePromiseQueueSync(queue){
    var seed = $.Deferred(),
        finalPromise;

    finalPromise = _.reduce(queue, function(memo, promise){
        return memo.then(function(){
            return promise.funct.apply(null, promise.argmnt);
        });
    }, seed.promise());

    seed.resolve();
    return finalPromise;
}

现在我可以用它来处理一些文件了:

_.each(fileList, function(element, index, list){
    _.each(element, function(el, idx, lst){
        promisesQueue.push({funct: processFile, argmnt:[el, index + (len - fileList.length) ,len]});
    });
});

执行并显示进度:

executePromiseQueueSync(promisesQueue).then(function(){
   ....
}, function(){
    ....
}).progress(function(msg, progress, name, index, status, desc){
        console.log('progress');
});

过程函数本身是这样的:

function processFile(file, index, size)
{
    var dfd = new jQuery.Deferred();
    if (file.name.match('(.*)\\.jpg'))
        ...
    else if
        ...
    else
       $.when(processWrongFileType(file)).then(function(){
         dfd.notify(...);
         dfd.resolve();
      });

    return dfd.promise();
}

如您所见,当文件类型错误时,您无事可做:

所以有时候我想像一个promise一样执行同步代码:

function processWrongFileType(){
    var dfd = new jQuery.Deferred();
    dfd.resolve();
    console.log("blah");
    return dfd.promise();
}

问题是如果 processWrongFileType 将被执行,notify 将不起作用。 如果我将 processWrongFileType 更改为如下所示:

function processWrongFileType()
{
    var dfd = new jQuery.Deferred();
    setTimeout(function(){dfd.resolve();},1);
    return dfd.promise();
}

notify() 会起作用。有什么方法可以避免 setTimeout 并仍然让 notify() 处理进度事件?

最佳答案

您无需执行任何特殊操作即可将同步代码用作 promise。

只返回 ==true 的值

$.when((function() {
    return prompt('really?')
})()).then((function() { 
    return alert('yeah') 
})()).done((function () { 
    alert('done') 
})())

关于javascript - 不是作为 jQuery Deferred 执行的异步函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15837964/

相关文章:

javascript - 在 jQuery 延迟对象中设置依赖关系的简写是什么?

coffeescript - IcedCoffeeScript 或 jQuery 延迟

javascript - 通过对 MongoDB 中数据的 API 调用为组件设置 props

javascript - 谷歌翻译 html 小部件不工作

jquery - 为什么 Firefox 3.6 会改变 jQuery 和 CSS 属性?

javascript - 如何重复相同的值直到最后一个文本框?

javascript - 如何将 JavaScript 值检查到 Rails 变量中

javascript - jQuery UI 可选 : Bind to first-generation children only

javascript - 如何使用这个 jQuery 来影响 css 不透明度

javascript - 如何排列 jQuery 延迟对象?