jjzjj

Promises

全部标签

javascript - 使用 Promises 的多路流的正确模式

所以最近几天我一直在玩promises,只是想转换一些项目,使用promises,但是我遇到这个问题不止几次。在阅读文章和教程时,一切看起来都很流畅和干净:getDataFromDB().then(makeCalculatons).then(getDataFromDB).then(serveToClient)但实际上并非如此。程序有很多改变整个流程的“if条件”:getDataFromCache(data).then(function(result){if(result){returnresult;}else{returngetDataFromDB();}}).then(functio

javascript - ECMAScript Promise.all 方法适用于 jQuery.Deferred。为什么?

我正在研究JavaScript中的Promises。我很感兴趣能否将ECMAScriptPromises与其他实现结合起来,例如jQuery$.Deferred。当Promises.all与jQuery$.Deferred一起正常工作时,我感到很惊讶。我试图在jQuery源代码和CommonJSPromises/A规范中找到答案,但我仍然误解了为什么这段代码按我预期的方式工作(在10秒后执行console.log,而不是5秒):varpromise=newPromise(function(resolve,reject){setTimeout(function(){resolve();/

javascript - 使用 Promises 使用 JavaScript 加载 jQuery

ApreviousquestionrevealedhowtoloadinjQueryusingnativeJavaScript.我已经成功地使用了那里的答案中的回调代码,复制在这里://Anonymous"self-invoking"function(function(){//Loadthescriptvarscript=document.createElement("SCRIPT");script.src='https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js';script.type='text/javas

javascript - 使用 promises 时如何在 Javascript 中出现异常后重试?

我正在使用Bluebirdpromise库。我有一系列promise的功能,如下所示:receiveMessageAsync(params).then(function(data)){return[data,handleMessageAsync(request)];}).spread(function(data,response){return[response,deleteMessageAsync(request)];}).spread(function(response,data){returnsendResponseAsync(response);}).then(function

javascript - Javascript promises 是否会阻塞堆栈

使用Javascriptpromises时,事件循环会被阻塞吗?我的理解是,使用await和async会使堆栈停止,直到操作完成。它是通过阻塞堆栈来实现这一点,还是类似于回调并将流程传递给各种API? 最佳答案 WhenusingJavascriptpromises,doestheeventloopgetblocked?没有。Promises只是一个事件通知系统。它们本身不是操作。他们只是通过调用适当的.then()或.catch()处理程序来响应被解决或拒绝,如果链接到其他promise,他们可以延迟调用这些处理程序直到他们所链接

javascript - 使用 Q promises 串行执行

我想我误解了Qpromise工作。我希望我的第一个promise在下一个promise开始之前解决,但那没有发生。这是我的代码:varQ=require('q');functiondoWork(taskName){vardeferred=Q.defer();console.log('starting',taskName);setTimeout(function(){console.log('donewith',taskName);deferred.resolve();});returndeferred.promise;}doWork('taskone').then(doWork('ta

javascript - 是什么决定了使用 promises 或 setTimeout 的延迟函数的调用顺序?

延迟函数的执行,例如在自定义事件处理中,是JavaScript中的一种常见模式(参见,例如here)。过去使用setTimeout(myFunc,0)是唯一的方法,但是有了promises现在有一个替代方法:Promise.resolve().then(myFunc)。我原以为它们几乎可以做同样的事情,但是在处理包含自定义事件的库时,我想我会发现是否存在差异,所以我将以下block放入Node中:varlogfn=function(v){returnfunction(){console.log(v)}};setTimeout(logfn(1),0);Promise.resolve().

javascript - Backbone JS Promises 在模型上设置属性之前解析

使用主干模型,假设它从服务器获取一些额外的属性(如“FirstName”和“LastName”),我有如下内容:varmyModel=newBackbone.Model({id:10});varmyOtherModel=newBackbone.Model({id:20});$.when(myModel.fetch(),myOtherModel.fetch()).done(function(){console.log(myModel.toJSON());});输出:{id:10}片刻后的输出:{id:10,FirstName:"Joe",LastName:"Schmo"}似乎Backbo

javascript - Express 中间件、next 和 Promises

有一个非常简单的带有处理程序的Express路由器:router.get('/users/:userId/roles/:roleId',function(req,res,next){constroleId=req.params.roleId;res.rest.resource=UserModel.findOne({_id:req.params.userId}).exec().then(function(usr){console.log(req.params.roleId);//=>undefinedconsole.log(roleId);//=>okayhereconstresult=

javascript - Angular : chaining promises over forEach loop

我无法理解promise。我正在使用GoogleEarthAPI进行地址“游览”。游览只是一个持续大约一分钟的动画,一个完成后,下一个应该开始。这是我的巡视功能:vartourAddress=function(address){returntourService.getLatLong(address).then(function(coords){returntourService.getKmlForCoords(coords).then(function(kml){_ge.getTourPlayer().setTour(kml);_ge.getTourPlayer().play();v