我有一个这样的对象数组:
聚合结果给我一个结构相同的结果如下:
results = [
{id: 1, test: biology, candidates:[ {cid: 11},{cid: 12},{cid: 13}]},
{id: 2, test: chemistry, candidates:[ {cid: 15},{cid: 16},{cid: 17}]},
{id: 3, test: physics, candidates:[ {cid: 1},{cid: 6},{cid: 7}]}
];
所以我需要在数组中循环,然后为每个候选人调用一个 promise 函数 getTotalMarksPerCandidate(它有一个 Promise.all 并在一些计算后解析变量)。但是,由于在数组中循环,不等待 promise 完成,我得到了 promise...
问题:你知道我怎样才能解决这个问题,以便在我的候选人数组中循环时,它会等待结果并继续吗?或任何周转解决方案?
所以我映射到结果数组,然后在候选数组中执行 forEach,以候选对象作为参数调用函数 getTotalMarksPerCandidate,将结果推送到 promise 数组中。然后将解决收到的所有 promise 。
var new_Result = results.map( function (subject) {
let promises = [];
if (subject.candidates && subject.candidates.length > 0) {
subject.candidates.forEach( (element) => {
promises.push(mobileUtil. getTotalMarksPerCandidate(element));
});
}
return Promise.all(promises).then( result => {
console.log('Check this out', result);
subject.newCandidatelist = result;
return subject;
});
});
console.log('R: ', new_Result);
resolve(params);
所以在 return Promise.all(promises) 回调函数中,我可以看到 promises 正在被解析,并且我看到函数 getTotalMarksPerCandidate 的返回值。我怎样才能将带有 totalMarks 的新候选对象设置为它们各自的父对象,如
new_results = [
{id: 1, test: biology, candidates:[ {cid: 11, score: 88},{cid: 12, score: 90},
{cid: 13, score: 91}]},
{id: 2, test: chemistry, candidates:[ {cid: 15, score: 91},{cid: 16, score: 91},
{cid: 17, score: 91}]},
{id: 3, test: physics, candidates:[ {cid: 1, score: 91},{cid: 6, score: 91},
{cid: 7, score: 91}]}
];
谢谢
最佳答案
一种完全基于嵌套 Promise 链的方法如下:
/*
Obtain array of promises via results.map() and resolve each sequentially
*/
const new_Result = Promise.all(results.map((subject) => {
/*
Start a promise chain for this subject
*/
return Promise.resolve()
.then(() => {
/*
Get candidates from current subject, or just an empty array if no valid candidates data present
*/
const candidates = Array.isArray(subject.candidates) && subject.candidates.length > 0 ? subject.candidates : [];
/*
Map candidates (if any) to this Promise.all()
*/
return Promise.all(candidates.map((candidate) => {
return mobileUtil.getTotalMarksPerCandidate(element).then(function(score) {
/*
Assign the score returned from getTotalMarksPerCandidate() for current candidate object
*/
candidate.score = score;
/*
Return the updated candidate to mapped array of promise results
*/
return candidate;
})
}));
})
.then((result) => {
console.log('Check this out', result);
subject.newCandidatelist = result;
return subject;
});
}));
这里的关键添加是这些行,它们基本上将从 getTotalMarksPerCandidate() 的已解决 promise 返回的分数值“附加”到正在迭代的当前 candidate:
return mobileUtil.getTotalMarksPerCandidate(element).then(function(score) {
candidate.score = score;
return candidate;
})
希望对您有所帮助!
关于javascript - 如何处理嵌套循环中的 promise ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57566670/
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我脑子里浮现出一些关于一种新编程语言的想法,所以我想我会尝试实现它。一位friend建议我尝试使用Treetop(Rubygem)来创建一个解析器。Treetop的文档很少,我以前从未做过这种事情。我的解析器表现得好像有一个无限循环,但没有堆栈跟踪;事实证明很难追踪到。有人可以指出入门级解析/AST指南的方向吗?我真的需要一些列出规则、常见用法等的东西来使用像Treetop这样的工具。我的语法分析器在GitHub上,以防有人希望帮助我改进它。class{initialize=lambda(name){receiver.name=name}greet=lambda{IO.puts("He
我得到了一个包含嵌套链接的表单。编辑时链接字段为空的问题。这是我的表格:Editingkategori{:action=>'update',:id=>@konkurrancer.id})do|f|%>'Trackingurl',:style=>'width:500;'%>'Editkonkurrence'%>|我的konkurrencer模型:has_one:link我的链接模型:classLink我的konkurrancer编辑操作:defedit@konkurrancer=Konkurrancer.find(params[:id])@konkurrancer.link_attrib
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[
我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer