草庐IT

await-async

全部标签

javascript - Bluebird PromisifyAll 没有任何 Async 后缀,即可以替换原始功能吗?

Bluebird有一个promisifyAll函数“通过遍历对象的属性并在对象及其原型(prototype)链上创建每个函数的异步等价物来Promisify整个对象。”它创建带有后缀Async的函数。是否可以完全替换旧功能?被替换的函数就像原始函数一样工作,此外它们还返回一个Promise,所以我认为完全替换旧函数应该是安全的。varobject={};object.fn=function(arg,cb){cb(null,1)};Bluebird.promisifyAll(object);object.fn//donotwantobject.fnAsync//=>shouldrepla

javascript - 如何使用 async/await 去抖动?

我有一个输入框。在用户停止输入后,我想执行一个HTTP请求并等待结果。Here'sajsbin由于jsbin不允许网络请求,因此我使用setTimeout()代替。varlog=console.log.bind(console)vardelayedResults=newPromise(function(resolve){setTimeout(function(){resolve('WoooIamtheresult!')},3000);});document.querySelector('input').addEventListener('input',_.debounce(asyncf

javascript - await 是否保证在 JavaScript 中没有赋值的执行顺序?

主题。我可以说下面的两段代码是相同的吗:awaitsomeFunc()//noassignmentheredoSomethingAfterSomeFunc()和:someFunc().then(()=>doSomethingAfterSomeFunc())我试过了,看起来它们是相等的,但有疑问(例如一些优化) 最佳答案 展开DanD'sanswer(因为我花了一些时间弄清楚自己),我会再说一些关于执行流程的事情。实际上,使用await会阻塞调用它的方法的流程,直到它解析为止。假设我们有这个异步函数:constsomeFunc=(st

javascript - 使用 async 和 await with export const

我无法完成这项工作...它说:await是一个保留字。是的,当然是……而且我想使用它:)怎么了?exportconstloginWithToken=async()=>{returndispatch=>{dispatch({type:SESSION_LOGIN_IN_PROGRESS,payload:true})letstoredData=awaitReadFromLocalDB('user')console.log(storedData)if(!storedData){invalidToken(null,dispatch)}else{storedData=JSON.parse(stor

javascript - NodeJS, Async forEachSeries 执行顺序

只是想尝试使用NodeJS的异步模块。我有以下代码。vara1=[1,2,3,4,5,6,7,8];async.forEachSeries(a1,function(n1,callback){console.log(n1);vara2=[10,11,12,13,14];async.forEachSeries(a2,function(n2,callback){console.log(n1+""+n2);callback();});callback();});我想把上面代码的处理过程打印成这样111011111211311422102112122132143310311312313314..

javascript - Async/Await with Request-Promise 返回 Undefined

我有两个文件;server.js和scrape.js,下面是它们当前的代码片段。服务器.js:constscrape=require("./scrape");asyncfunctionstart(){constresponse=awaitscrape.start();console.log(response);}start();和scrape.js:constcheerio=require("cheerio");constrequest=require("request-promise");go=async()=>{constoptions={uri:"http://www.somew

javascript : Async/await in . 替换

我正在按以下方式使用async/await函数asyncfunction(){letoutput=awaitstring.replace(regex,async(match)=>{letdata=awaitsomeFunction(match)console.log(data);//givescorrectdatareturndata})returnoutput;}但是返回的数据是一个promise对象。只是对它应该在带有回调的此类函数中实现的方式感到困惑。 最佳答案 一些异步替换的易于使用和理解的函数:asyncfunctionr

javascript - `return await` 是否存在性能问题?

我看到有一个eslintrule,no-return-await,fordisallowingreturnawait.在规则的描述中,它指出returnawait添加了“在总体Promise解决或拒绝之前的额外时间”。但是,当我查看MDNasyncfunctiondocs,“简单示例”显示了一个包含returnawait的示例,但没有说明这可能是性能问题的原因。returnawait是否如eslint文档所建议的那样是一个实际的性能问题?如果是,怎么办? 最佳答案 不,没有任何性能问题。这只是一个不必要的额外操作。执行可能需要更长的

javascript - Babel - 使用 transform-async-to-generator 插件时未定义 regeneratorRuntime

我无法正确设置babel以使用async/await。我正在使用babel7和webpack4。如果可能,我不想使用babel-polyfill!我的babelrc文件:{"presets":[["@babel/env",{"modules":false}]],"plugins":["syntax-dynamic-import","transform-async-to-generator"]}代码:asyncfunctioninit(){constloaderData=awaitinitLoader();initCmp(loaderData).then(initApi(loaderDa

javascript - 在 await 之后调用 setState 时状态立即可用

在等待另一个函数并将状态记录到控制台后调用setState-该值立即可用。我知道setState是异步的,在所有其他情况下,它不会在调用后立即可用(但会在setState回调中可用)在没有等待的情况下使用(预期)//initalvaluestateis0constresponse=fetchSomething()this.setState({value:5})console.log(this.state.value)//prints0与等待一起使用//initalvaluestateis0constresponse=awaitfetchSomething()this.setState(