草庐IT

promised-mongo

全部标签

javascript - 限制正在运行的 promise 的并发

我正在寻找一个promise函数包装器,它可以在给定的promise运行时限制/节流,以便在给定的时间只运行一定数量的promise。在下面的例子中,delayPromise永远不会同时运行,它们应该以先到先得的顺序一次运行一个。importPromisefrom'bluebird'function_delayPromise(seconds,str){console.log(str)returnPromise.delay(seconds)}letdelayPromise=limitConcurrency(_delayPromise,1)asyncfunctiona(){awaitdel

javascript promise 递归

我有一个异步递归函数,如果还有更多工作要做,它会返回promise,否则返回结果数组。如果不涉及递归,它会正确返回数组,但是当存在递归时,数组是未定义的。代码是functionfoo(filepath){varresultArr=[];functiondoo(file){returnasyncOperation(file).then(resp=>{resultArr.push(resp.data);if(resp.pages){varpages=resp.pages.split(',');pages.forEach(page=>{returndoo(page);});}else{ret

javascript promises、事件循环和作业队列

考虑以下代码:functionfoo(){console.log('foo');newPromise(function(resolve,reject){setTimeout(function(){resolve('RESOLVING');},5000);}).then(function(value){console.log(value);});}foo();我试图正确理解这里发生的事情:在执行newPromise时,“executerfunction”直接运行,当setTimeout被调用时,安排一个操作将新条目添加到“事件队列”(5秒后)因为调用then一个添加到“作业队列”的操作,

javascript - 使用 Promises 处理分支

我有一个关于jQuery1.9.1promises的问题,我可能需要条件逻辑来返回另一个deferred而我不确定如何处理它。这是我最好的尝试,但正如下面的评论所示,当我点击else分支时,我仍然点击了第二个.then()函数,我希望我可以在那里返回给用户。如何处理这种情况的任何模式?storage.provision(c).then(function(rc){if(rc===0){storage.write(c);}else{returnoptions.onSuccess(rc);//howigotbacktotheuserscallbacks/promise,butthis//ta

javascript - 排队 promise

我使用mbostock/queue用于排队一些异步操作。更多的是速率限制(UI生成的事件很少,后端可以慢慢处理),并确保它们按顺序处理。我像这样使用它functionrequest(d,cb){//someasyncoperadd.then(function(){cb(null,"finished")})}varaddQ=queue(1);addQ.defer(request)//calledbyfewreqathigherratesgeneratedbyUI我已经使用angular.js$q进行异步操作。那么,我是必须使用mbostock/queue,还是可以用$q构建一个队列(本质

javascript - Bluebird.js 自定义错误捕获功能,不适用于第一个 promise ?

我正在尝试使用Bluebird.js的自定义错误处理程序。在下面的示例中调用了包罗万象的处理程序,而不是MyCustomError处理程序,但是当我将拒绝移动到then函数(并解决了firstPromise...)时,MyCustomError处理程序叫做。这是为什么?有什么问题吗?谢谢。varPromise=require('bluebird'),debug=require('debug')('main');firstPromise().then(function(value){debug(value);}).catch(MyCustomError,function(err){deb

javascript - 使用 Chai 解决 Protractor 和 Cucumber 中的 promise

最近,我和一位同事对使用Protractor和Chai实现Cucumber步骤定义的“正确”方式存在一些分歧。我们的争论源于对Cucumber上下文中promise解决方案的确切情况的相互缺乏理解。我们正在针对AngularJS应用程序进行测试,因此解决promise和异步行为是不可避免的。我们遇到的最大问题是强制执行同步测试行为并让Cucumber在步骤定义之间等待promise。在某些情况下,我们观察到这样的情况,即Cucumber似乎在Webdriver执行步骤定义之前就直接完成了步骤定义。我们对这个问题的解决方案各不相同......考虑假设场景:Scenario:Whenaus

javascript - 循环 promise

我处于这样一个场景中,我必须按顺序从服务器获取数据,我想在Promises的帮助下做到这一点。到目前为止,这是我尝试过的:functiongetDataFromServer(){returnnewPromise(function(resolve,reject){varresult=[];(functionfetchData(nextPageToken){server.getData(nextPageToken).then(function(response){result.push(response.data);if(response.nextPageToken){fetchData(

javascript - React 组件抛出的错误,被不相关的 promise 的 catch block 捕获

这是我遇到的。在React组件的渲染函数的某处,我有这个:{first_name}{last_name}我用这个替换了它:{first_name.toUpperCase()}{last_name.toUpperCase()}我的应用程序无法再登录。我正在使用Axios与后端对话。Axios是基于promise的。在我进行了上述更改之后。它显然开始执行我的loginAPI调用的then和catchblock。当我在catchblock中打印响应时。functionlogin(data,success,error){axios.post('/login',JSON.stringify(da

javascript - 有没有一种方法可以创建在加载 Google Maps Javascript API 时解析的 promise ?

应该加载GoogleMapsJavascriptAPIthisway:functioninitMap(){console.log('loaded');}如果我必须回答我的问题,我会这样做:vargoogleAPILoadedPromise=Promise.pending();functioninitMap(){googleAPILoadedPromise.resolve();}googleAPILoadedPromise.promise.then(function(){console.log('loaded');});但是延迟已被弃用并且可能被视为反模式,至少在bluebird中是这样