首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Promises和并发

Promises和并发
EN

Stack Overflow用户
提问于 2015-05-08 15:30:48
回答 2查看 121关注 0票数 0

我要再问一次这个问题,因为我上次没有想到正确的问题。

假设我有一个数组中的jQuery选择器集合:

代码语言:javascript
复制
[{menu:'.menu-a',click:'.menu-a-click'},...]

我想遍历这些选择器,如果menu不存在,那么如果click存在,那么单击...

这就是麻烦开始的地方。我需要单击一次,然后在再次单击之前进行超时-这允许菜单由另一个脚本构建,第二次单击将隐藏它。

我想用Promise来规范所有的点击。这就像架起一串鞭炮,然后点燃第一个……但承诺会立即执行。我该怎么做呢?

我可以用普通的JS编写代码,但我想学习其他方法。我猜是和allmap有关的东西。

EN

回答 2

Stack Overflow用户

发布于 2015-05-08 19:20:44

这是我想出来的。打败了一头三条腿的毛驴。

代码语言:javascript
复制
var menus=[{id:0},{id:1},{id:2},{id:3}];

function doer(menu){
    return new Promise(function called(res,rej){
      console.log('click1:'+menu.id);
      setTimeout(function(){
        if(menu.id===2){return rej(new Error('could not'));}
        console.log('click2:'+menu.id);
        res(1);// happy
      },Math.random()*8000);
    });  
}

Promise.reduce(menus,function(ctr,cur,i){
  return doer(menus[i]).then(function(res,rej){
     console.log('happy:',res);
  });
},$.when(1)).then(function(){
  console.log('everyones done'); //no errors
}).catch(function(eee){
  console.log('Error:',eee);
}).finally(function(){
  console.log('finally');
});

这是蓝鸟,如果这很重要的话。我不知道蓝鸟$.when(1)的等价物。

票数 1
EN

Stack Overflow用户

发布于 2015-05-08 15:39:13

正如你在这里看到的:

图片来源:

在promise实现后,您可以使用onFulfillment回调来完成必要的工作。

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

https://stackoverflow.com/questions/30118245

复制
相关文章

相似问题

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