草庐IT

promise-then

全部标签

javascript - 如何为我的任务实现实现 Promise.all 的等价物?

这是我的Task实现(即一种Promise但遵守monad法则并且可取消)。它工作坚如磐石:constTask=k=>({runTask:(res,rej)=>k(res,rej)});consttAp=tf=>tk=>Task((res,rej)=>tf.runTask(f=>tk.runTask(x=>res(f(x)),rej),rej));consttOf=x=>Task((res,rej)=>res(x));consttMap=f=>tk=>Task((res,rej)=>tk.runTask(x=>res(f(x)),rej));consttChain=fm=>mx=>Ta

javascript - 将回调变成 promise

我正在使用googlemapsapi,这段代码异步返回地点列表。我怎样才能调用这个函数并让它在收集完所有数据后触发一些东西?到目前为止,这是我尝试过的-$.search=function(boxes){functionfindNextPlaces(place_results,searchIndex){vardfd=$.Deferred();if(searchIndex 最佳答案 要回答标题所暗示的问题,“将回调转化为promise”,简单的答案是使用一个非常简单的“promise模式”(我的术语),其中Deferred的.resol

javascript - 如何捕获 promise 运行时 Javascript 错误?

我目前正在实现一个基于PDF.js的PDF查看器,作为其中的一部分,我了解了promise对象。我还了解到运行时错误不会自动显示在调试控制台中:PDFJS.getDocument(...).then(function(pdfDocument){alert(UndefinedVariable);//Notshowninconsole!},function(error){console.log("Erroroccurred",error);});除了按照http://www.asyncdev.net/2013/07/promises-errors-and-express-js/中的描述添加

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 - 如何理解这段 Promise 代码?

'usestrict';Promise.resolve(()=>'John').then((args)=>{console.log(args);thrownewError('ops')}).catch((ex)=>{console.log(ex)}).then(()=>{thrownewError('ups')console.log('Doe')})我认为console.log(args);应该输出'John',但是当我运行这段代码时,输​​出是[[Function]]所以我很困惑。 最佳答案 Promise.resolve将使用您

javascript - 为什么来自 Promise `.then` 方法的回调是一种反模式

我在StackOverflow上看到了人们建议为AngularJS服务提供回调函数的答案。app.controller('tokenCtrl',function($scope,tokenService){tokenService.getTokens(functioncallbackFn(tokens){$scope.tokens=tokens;});});app.factory('tokenService',function($http){vargetTokens=function(callbackFn){$http.get('/api/tokens').then(functionon

javascript Promise.all 只返回最后一个 promise

我有一个这样的脚本:vara=[{'a':1},{'b':2}]varallPromises=newArray(a.length)for(variina){allPromises[i]=Promise.resolve().then(response=>{console.log(i)console.log(a[i])//Dosomethigoneveryloopwithkeyandvaluereturni})}Promise.all(allPromises).then(response=>console.log(response))在我的for循环中,它只给我最后一个索引和最后一个索引的

javascript - 在 promise 解决后修改组件状态

我想在promise解决后修改组件的状态(reactnative)。这是我的代码:classGreetingextendsComponent{constructor(props){super(props);this.state={text:'Starting...'};varhandler=newRequestHandler();handler.login('email','password').then(function(resp){this.setState({text:resp});});}render(){return(Resp:{this.state.text});}}但是当

javascript - Firebase .then 与 .on ('value' )

我试图让.then()与.on()一起工作,但它只与.once()一起工作.我得到playersRef.on(...).thenisnotafunction,当用on()尝试它时所以我现在拥有的是:letnodesRef=Firebase.database().ref('players')letanswers={}playersRef.on('value',(playersSnapshot)=>{playersRef.once('value').then((playersSnapshot)=>{playersSnapshot.forEach((playerSnapshot)=>{let

javascript - Promise.all() 使用 Backbone 解决 IE 11

背景:我的任务是帮助解决出现以下错误的问题:'Promise'isundefined'这是我们的sessionsmodel.js脚本的一部分:returnPromise.all(promises);promises是一组需要发生的操作,如果有任何失败,它将被拒绝。问题:根据我的研究,IE不支持Promise那么是否有解决方法可以应用于此返回值来完成同样的事情? 最佳答案 由于您使用的是Backbone,所以promise可能是jQuerypromise。你可以使用jQuery.whenfunction与Promise.all相同:r