草庐IT

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)isnotiterable执行

javascript - Promise.then(a, b) 和 Promise.then(a).catch(b) 一样吗?

这个问题在这里已经有了答案:Whenis.then(success,fail)consideredanantipatternforpromises?(7个答案)关闭4年前。有什么区别myPromise.then(a,b)myPromise.then(a).catch(b)?无论myPromise的内容和状态以及函数a和b的实现如何,这两个JavaScript表达式是否总是产生相同的结果?除了代码可读性之外,在什么情况下我应该更喜欢使用其中一种?

javascript - 为什么 .then() 在没有 JavaScript promise 的情况下工作?

为什么调用第二个函数.then(notPromise)仍然将参数传递给第三个函数.then(promiseC)即使notPromise()只是一个常规函数?我认为只有promises可以与.then()一起使用,但它仍然以某种方式正确执行(并传递参数)。promiseA().then(notPromise).then(promiseC);functionpromiseA(){returnnewPromise(function(resolve,reject){conststring="a";resolve(string);});}functionnotPromise(string){co

javascript - 链式 jQuery promises with abort

我目前正在编写API代码,其中包含多层深度的$.ajax()调用。一个要求是用户必须能够取消任何请求(例如,如果它花费的时间太长)。通常这是通过一些简单的事情来完成的,比如:varjqXHR=$.ajax(..);$(mycancelitem).click(function(){jqXHR.abort();});但是我的代码看起来更像这样:functionmyapicall(){varjqxhr=$.ajax(…);varprms=def.then(function(result){//modifytheresultherereturnresult+5;});returnprms;}这

javascript - ES7 async/await 概念问题

我正在迁移现有程序以使用async/await(通过Babel的bluebirdCoroutines)为了学习这种风格。我一直在看这个tutorial.我对以下行为有点困扰。此代码段按预期工作:letparts=[];leturlsP=urls.map((url,index)=>{returndlPart(url,index,tempDir);});for(leturlPofurlsP){//Parallel(yay!)parts.push(awaiturlP);}for(letpartofparts){//SequentialawaitappendFile(leFile,part);

javascript - 用 Bluebird 链接递归 promise

我有一个promise链,中间有一个递归promisedoAsyncRecursive(),如下所示:doAsync().then(function(){returndoAsyncRecursive();}).then(function(){returndoSomethingElseAsync();}).then(function(result){console.log(result);}).catch(errorHandler);doAsyncRecursive()必须做一些事情,如果一开始没有成功,我之后想每5秒尝试一次,直到它成功。这是我的promise函数的样子:functio

javascript - 仅在某些 promise 已解决后才导入/导出

假设我有一个包含某些promise的文件,当按顺序执行时,它会准备一个输入文件input.txt。//prepareInput.jsvarstep1=function(){varpromise=newPromise(function(resolve,reject){...});returnpromise;};varstep2=function(){varpromise=newPromise(function(resolve,reject){...});returnpromise;};varstep3=function(){varpromise=newPromise(function(r

javascript - 使用 promise 时我仍然会遇到厄运金字塔,我做错了什么?

我正在使用Inquirer使用Node.js的库,在使用promise时我仍然会遇到厄运金字塔,我做错了什么?仅供引用,查询器库API基本上是:inquirer.prompt([question1,question2,question3,...questionX]).then(function(answers){});其中answers是一个散列,带有代表每个问题的键。这里没有什么特别的地方。无论如何,使用API,我总是得到getAnswersToPrompts().then(function(answers){})并且将promise嵌套在前一个中似乎更方便......比如所以:fu

javascript - 如何使用 angular2 和 typescript 链接 3 个 Promise

我已经成功地链接了promise,但我发现我做这件事的方式足够复杂:我想知道是否有更优雅的方式来做到这一点。我使用Angular2、Typescript和signalR。我有一个服务getIntervention,它通过Id从服务器返回一个对象。在调用getIntervention之前,我想检查要连接到服务器的客户端,在连接到服务器之前,我想要加载SignalR脚本。所以我创建了第一个promisescriptLoadedPromise,它等待加载SignalR脚本。当scriptLoadedPromise被解析时,一个新的promiseconnectionPromise被创建,等待连

javascript - 为什么我要使用 Redux Promise 中间件而不是 Redux Promise?

我用过ReduxPromise,但似乎ReduxPromiseMiddleware具有更多功能,例如分派(dispatch)多个附加了“PENDING”或“FULFILLED”的操作。为什么我要用一个而不是另一个? 最佳答案 我个人更喜欢ReduxPromiseMiddleware作为中间件,因为它支持乐观更新;调度未决、已完成和已拒绝的操作;并与ReduxThunk配合得很好链接异步操作。例如,您可以在reducer中使用带有_PENDING和_FULFILLED的操作,并使用进度条等更新UI。