草庐IT

Async-await

全部标签

javascript - 无法转换包含异步等待的 TypeScript

当尝试转译以下包含async和await关键字的TypeScript代码时asyncfunctionfoo(){awaitbar();}出现以下错误src/aa.ts(1,7):errorTS1005:';'expected.src/aa.ts(2,11):errorTS1005:';'expected.结果是一个包含此内容的.js文件async;functionfoo(){await;bar();}我正在使用这些tsc选项:-tes6-mcommonjs,遵循thisMSDNblog上的说明.我安装了TypeScript1.8.9。有什么想法吗? 最佳答案

javascript - 使用 nodeJS async-await 反复提示用户直到解决

我尝试反复向用户提问,直到他们使用此代码给出正确答案。问题是,如果用户没有在第一时间给出正确答案,则无法解决。varreadline=require('readline');varrl=readline.createInterface({input:process.stdin,output:process.stdout});functionpromptAge(){returnnewPromise(function(resolve){rl.question('Howoldareyou?',function(answer){age=parseInt(answer);if(age>0){re

javascript - jquery .done() 中的异步回调函数未执行

为什么将异步函数作为jQuery的回调函数deferred.done()不行?即为什么jqueryObj.fadeTo("slow",1).promise().done(asyncFunc);不行,但是jqueryObj.fadeTo("slow",1).promise().done(function(){asyncFunc(););是吗?(另外,请注意jqueryObj.click(asyncFunc)确实有效。)例子:TitleItemItem...标题完成淡入后,列表中的每个项目按顺序淡入。淡入淡出时间为20000毫秒,但列表项之间的延迟为250毫秒(因此下一个列表项开始淡入,而

javascript - 使用 node.js async forEachSeries 时是否有与 'continue' 等效的语句?

我正在使用node.js异步包,特别是forEachSeries,根据从数组中提取的参数发出一系列http请求。在每个请求的回调中,我有一些if/else语句来响应不同类型的响应。//ThisisthecallbackofaGETrequestinsideofaforEachSeriesfunction(error,response){if(response.results){//Dosomethingwithresults}elseif(!response.results){//Wouldliketouseacontinuestatementhere,but//thisisnotin

javascript - Node : Passing function specific variables to Async. 并行()

在Node中呈现页面之前,我需要完成大量长时间运行的数据库查询。这些查询中的每一个都需要一些自己的变量。有没有一种简单的方法可以将变量传递给nodejs中的async.parallel()实用程序?async.parallel([queryX(callback,A1,A2,A3),queryX(callback,B1,B2,B3),queryY(callback,C1,C2,C3),queryY(callback,D1,D2,D3),queryZ(callback,E1,E2,E3),queryZ(callback,F1,F2,F3),],function(err,results){/

javascript - 如何处理 Node.js expressjs 中异步对象方法中未处理的 promise 拒绝?

我在对象内部使用异步函数在express.js中发送响应Controller代码:module.exports={asyncsignUpEmail(req,res){/***@descriptionParametersfrombody*@param{string}firstName-FirstName*@inner*/constfirstName=req.body.firstName;res.send({success:name});thrownewError();//purposelyDone}}问题:因为signUpEmail方法在我的例子中是异步的,无论我的异步方法在这里抛出什么

javascript - 在异步函数内的回调中调用 await

这是一些代码(这是一个过于简化的示例,我知道它很愚蠢):functionsleep(ms){returnnewPromise(resolve=>setTimeout(resolve,ms));}asyncfunctiontest(){[1,2,3].map(()=>{console.log('test');awaitsleep(1000);});}test();目标是:显示测试然后等待一秒钟然后显示测试然后等待一秒然后显示测试然后等待一秒但是运行这段代码会导致失败:awaitisareservedword我知道我可以使用for循环修复它:asyncfunctiontest(){for(

javascript - Fetch API 在 React Native 中返回旧数据

描述:我正在制作一个reactnative应用程序,其中我有一个我关注的github用户列表,我想实现取消关注和刷新列表的功能。我制作了两个异步助手来与githubAPI交互,一个用于取消关注用户(通过PUT),另一个用于获取关注列表(通过GET)。我还在以下组件列表中添加了一个firebase监听器。每个关注都会将我导航到一个由取消关注按钮组成的个人资料View。当我单击一个按钮时,它应该取消关注用户,更新组件中的关注者列表,然后导航回关注者列表组件。问题取消关注用户按预期工作,但关注ListView仍包含旧列表。我的代码返回旧数据,即使githubapi返回新的更新数据,所以我怀疑

javascript - 为什么 async-await 一起运行时比 promises 慢得多

我发现在某些情况下运行async-await会慢很多。functionmakeAPromise(){returnPromise.resolve(Math.random());}functionusingPromises(){constbefore=window.performance.now();returnmakeAPromise().then((num)=>{constafter=window.performance.now();console.log('Total(promises):',after-before,'ms');returnnum;})}asyncfunctionu

javascript - 为什么 'await' 在 '.then()' 函数返回的代理上触发 'async'?

我正在使用babel(env)编译代码,向下编译为ES5。代码如下:(async()=>{constp=async()=>{returnnewProxy({},{get:(target,property)=>{console.log(property);}})};constr=awaitp();//awaitcalls.thenontheresultofp()})(); 最佳答案 它实际上发生了两次。Whyis.then()triggeredonaProxyreturnedbyanasyncfunction?asyncfunctio