草庐IT

promised-mongo

全部标签

javascript - 使用 mocha 的内置 promise 支持测试失败的 promise

这个问题在这里已经有了答案:HowdoIproperlytestpromiseswithmochaandchai?(4个答案)关闭6年前。我应该如何使用mocha和chai来测试我的promise是否失败?我很困惑,因为我最初认为我应该使用'mocha-as-promised',但是那包现在已弃用(我正在使用mocha2.1.0),并建议只需使用现在内置于mocha中的promise测试。参见:https://github.com/domenic/mocha-as-promised另一篇文章建议取消对it()回调-不确定我明白为什么,因为我的理解是传递“完成”参数是表示测试已经完成的方

javascript - 从 Promise.all 合并许多数组

当Promise.all完成时,它返回一个包含数据的数组。在我的例子中,数组只是数字:[[1,4,9,9],[4,4,9,1],[6,6,9,1]]数组可以是任意大小。目前我正在这样做:letnums=[]data.map(function(_nums){_nums.map(function(num){nums.push(num)})})有没有其他方法可以做到这一点?lodash是否有任何功能可以做到这一点? 最佳答案 ES2019介绍Array.prototype.flat这大大简化了这一点:constnums=data.flat

javascript - 我如何在 Meteor 的 Mongo 查询中使用变量作为字段名称?

我将如何在Meteor应用程序的Mongo查询中使用变量作为字段名称。这是一个例子...在将子项的父ID的集合名称大写后,这会在我的请求Controller集合上运行查找。子项是users字段。window[Meteor.request.controller.capitalise()]["find"]({_id:Session.get('parent_id'),users:params.child}).count()如您所见,我的Controller是集合项的变量名称,它允许我使用一行代码来查找Controller/集合的子项,但我需要能够将子字段名称设置为变量。在上面的示例中,它是u

javascript - 加载文件后如何将 promise 错误传播到更高的 promise 级别?

我正在使用bluebird开发异步脚本加载器我正在努力将错误传递到我可以捕获它的地方。加载文件后,我将调用名为declare的方法,如下所示:declare("storage",[{"name":'util',"src":'../src/util.js'}],function(util){varstorage={};//...stuffwithutilreturnstorage;});声明是:declare=function(name,dependency_list,callback){varresolver;//digestpromisesreturnedforeachmodulef

javascript - 使用 EventListener 解决 promise

我正在处理一个弹出式div,我想在动画上附加一个promise,这样我就可以在弹出式窗口结束后做一些事情。我的方法不起作用,因为我找不到将promise传递给事件处理程序上的函数的方法。似乎你不能在这里使用bind。我已经尝试过,虽然我可以解决promise,但我无法删除事件处理程序这里会有什么不同的解决方案?functionEventListenerForPopUp(){this.removeEventListener("animationend",EventListenerForPopUp);this.Show.resolve();}functionShowHideDiv(){th

javascript - 如何在异步/等待语法中使用 Promise.prototype.finally()?

实际上我的主要问题是在async/awaitES8语法中使用Promise.prototype.catch(),毫无疑问是Promise。prototype.then()存在于async/await语法的本质中。我搜索了关于在async/await中使用Promise.prototype.catch()并找到了这个:async()=>{try{constresult1=awaitfirstAsynchronousFunction();constresult2=awaitsecondAsynchronousFunction(result1);console.log(result2);}c

javascript - task.js 生成器/ promise 与异步回调

我想知道在处理JavaScript中的异步代码时,这两种方法中哪种方法更好。我想了解哪种方法可以生成更清晰的代码。我习惯于使用promises,它们似乎比异步方法(https://github.com/caolan/async)更灵活。我也知道Task.js库(http://taskjs.org/),但这依赖于作为EcmascriptHarmony一部分的yield关键字。 最佳答案 async库封装了几个非常常见的异步模式,包括并行进行任意异步调用和异步迭代列表。它旨在与“nodeback”(err,res)API一起使用,这使得

javascript - JS Promises/A+ 的 'catch' 方法名称是否无效,因为它是 JS 关键字?

最近开始在一个项目中使用JSPromises。我注意到每次我使用.catch我的JSlinter提示。它确实运行并做了它应该做的事情,但我查找了ECMAScriptspec它看起来真的是对的:因为catchisakeyword它不能用作标识符。据我了解,方法名称是标识符,因此这是无效的:Promise.reject("Duh").catch(alert);应该是这样的:Promise.reject("Duh")['catch'](alert);我错过了什么? 最佳答案 WhatamImissing?属性名称不是标识符,它可以使用任何

javascript - 我可以触发并忘记 nodejs (ES7) 中的 promise 吗?

我想用babel运行这段代码:redisClientAsync.delAsync('key');returnawaitsomeOtherAsyncFunction();在第一行没有await的异步函数中。这样可以吗?我还能如何运行我不关心的东西?我可以在没有回调的情况下触发非promise函数del('key',null)吗? 最佳答案 是的,你可以这样做,它会并行运行两个异步函数。您刚刚创建了一个promise并将其丢弃。但是,这意味着当promise被拒绝时,您不会注意到。你只会getanunhandledRejectionev

javascript - RxJS:连接三个 promise ,区分结果

我有三个promise,Rest请求返回数据列表。第三个有对前两个列表的引用(ids),所以我想在我拥有所有数据时将这些ids映射到相应的名称。映射不是问题,我只是为此使用了Lodash。但问题是在开始计算此映射之前等待三个promise解决。我想到了使用concat():Rx.Observable.concat(p1,p2,p3).subscribe(functiononNext(list){//Assignthelisttothecorrespondingvariableinthescope},functiononError(e){//Notifyoferror},function