TOGOUTECH

async-await

全部标签

Javascript 如何通过解构将 promise.spread 语法迁移到异步/等待

我正在清理一些sequelize代码,findOrCreate函数返回一个需要展开才能获得实际结果对象的promise。我想重写我的代码以使用await代替,并且鉴于ES6支持数组解构,我认为用它代替User.findOrCreate({where:{mcId},defaults}).spread((user,created)=>{//dostuff})我能做到const[user,created]=awaitUser.findOrCreate({where:{mcId},defaults})但事实并非如此。我收到错误(intermediatevalue)isnotiterabl

javascript - 动态创建异步函数

我想知道是否可以像这样动态创建一个异步函数:newFunction('awaitPromise.resolve()');预期,前面的代码抛出:UncaughtSyntaxError:awaitisonlyvalidinasyncfunction 最佳答案 是的,您可以获得对非全局的引用AsyncFunction动态创建异步函数的构造函数。您可以像这样获得对AsyncFunction构造函数的引用:constAsyncFunction=Object.getPrototypeOf(asyncfunction(){}).c

javascript - Typescript/ES7 中异步/等待的有限并行性

我一直在尝试使用Typescript,但我现在对如何有效使用async/await有点困惑。我正在向数据库中插入一堆记录,我需要获取每次插入返回的ID列表。下面的简化示例一般有效,但它并不像我想要的那样优雅,而且它完全是顺序的。asyncfunctiongeneratePersons(){constnames=generateNames(firstNames,lastNames);letids=[]for(letnameofnames){constid=awaitdb("persons").insert({first_name:name.firstName,last_n

javascript - 如何在 Gulp 4 中使用异步/等待?

我正在尝试做这样的事情:gulp.task("test",async()=>{returngulp.src("**/*.scss").pipe(print((filePath)=>`File:${filePath}`));});(打印为gulp-print)但它给出了以下内容:[22:08:43]Starting'test'...[22:08:43]Finished'test'after12ms[22:08:43]File:src\app\styles\app.scss[22:08:43]File:src\ap

javascript - 如何使用 axios 和 async/await 断言错误

我正在尝试编写一个测试,断言Async/Await和axios引发了特定类型的错误。但是,当我运行测试时,我得到以下信息。为什么jest没有正确地拒绝我的promise?谢谢!Error:expect(received).rejects.toThrow()ExpectedreceivedPromisetoreject,insteaditresolvedtovalue{"data":"response","status":404}api.js:importaxiosfrom'axios';importSpecialError

javascript - 服务人员 : async await in combination with waituntil is not working properly

在使用async/await语法时,我正在为serviceworker中的promises而苦苦挣扎。以下情况:我收到推送通知,想处理点击事件。如果我将“旧”语法与then和catch一起使用,我可以遍历客户端列表并对其执行一些操作。如果我对async/await使用我喜欢的方式,它不会做任何事情。self.addEventListener("notificationclick",event=>{//isworkingevent.waitUntil(self.clients.matchAll().then(clientList=>{console.log(c

javascript - 如何计算 JavaScript 中异步函数的执行时间?

我想计算异步函数(async/await)在JavaScript中花费了多长时间。可以这样做:constasyncFunc=asyncfunction(){};constbefore=Date.now();asyncFunc().then(()=>{constafter=Date.now();console.log(after-before);});但是,这不起作用,因为promise回调在新的微任务中运行。IE。在asyncFunc()结束和then(()=>{})开始之间,任何已经排队的微任务将首先被触发,它们的执行时间将为考虑在内。例如:constasyncFunc=asy

javascript - 为什么 await 只适用于 javascript 中的异步函数?

只是通过这个tutorial,令我困惑的是为什么await只适用于async函数。来自教程:Assaid,awaitonlyworksinsideasyncfunction.根据我的理解,async将函数返回对象包装成一个Promise,所以调用者可以使用.then()asyncfunctionf(){return1;}f().then(alert);//1await只是等待promise在async函数中解决。asyncfunctionf(){letpromise=newPromise((resolve,reject)=>{setTimeout(()=>resolve(&

JavaScript - 同步等待异步操作(休眠)

我知道这里被问过很多次,也回答过很多次,这不是应该如何完成的方式,但再一次:)是否有可能以某种方式调用异步函数(例如计时器/ajax调用),基本上是常见的异步任务并同步等待直到它结束而不会出现100%CPU使用率和浏览器阻塞?简单的回答就足够了——是或否。如果不是,我必须根据“异步方式”中的异步操作编写所有代码,否则会更好;)想象一下:updateCSS("someurl.css")functionupdateCSS(url){varcss=getCachedResource(url);css=css.replace(/regexp/gm,function(curUrl

javascript - 等待循环内的 promise

letcurrentProduct;for(leti=0;i<products.length;i++){currentProduct=products[i];subscription.getAll(products[i]._id).then((subs)=>{update(subs,currentProduct);});}我正在使用bluebird,方法getAll和update返回promise。我怎么能说“等到两个promise返回,然后更新currentProduct值”?我对JS很陌生...... 最佳答案 如果