我是mongo db和meteor的新手。我有一份文件如下: 砑光:
{
"_id" : ObjectId("577a09d3e9ac22d62a20ab01"),
"status_visualizacion" : "visible",
"status_tipo" : "Pintura",
"createdAt" : ISODate("2016-07-04T07:01:39.018Z"),
"usuarios_admin" : [
ObjectId("5773976c201bb491f499c180"),
ObjectId("577a03db9da98306f624c3d9"),
ObjectId("577a041d9da98306f624c3da"),
ObjectId("577a07b7e9ac22d62a20aae9"),
ObjectId("577a07c6e9ac22d62a20aaea"),
"Ys6fiychXcSfCgWox"
],
"grupo_usuarios" : [
ObjectId("5773976c201bb491f499c180"),
ObjectId("577a03db9da98306f624c3d9"),
ObjectId("577a041d9da98306f624c3da"),
ObjectId("577a07b7e9ac22d62a20aae9"),
ObjectId("577a07c6e9ac22d62a20aaea")
],
"calendario_slaves" : [
ObjectId("577b6a0114b9512e1e3f4c10"),
ObjectId("577b6a1d14b9512e1e3f4c11"),
ObjectId("577b6a2414b9512e1e3f4c12")
]
}
我希望在其他客户端帮助程序中检索属于此特定日历的所有calendarios_slaves的所有ID,以使用它们来查询特定的calendarios_slave。我尽我所能,但一切都没有结果。我现在的代码就是:
Template.testeo.helpers({
ls: function(){
var list=Calender.find({status_visualizacion: "visible"});
var result="";
list.forEach(function(calender){
result += calender.calendario_slaves + " ";
});
console.log(result);
console.log("split");
mySplitResult = result.split(",");
for ( var i = 0; i < mySplitResult.length; i++ ) {
mySplitResult2 =mySplitResult[i].split(" ")
for ( var j = 0; j < mySplitResult2.length; j++ ) {
myTrozo= mySplitResult2[j];
console.log(myTrozo);
}
}
//console.log(myTrozo);
return myTrozo;
}
});
我设法检索了这个Calender的所有calendario_slave的所有ID,但是他们都在一行中所以我实现了SPLIT以使用while循环拆分它们但现在的问题是我无法访问SPLIT结果(myTrozo)在for循环之外,第一个console.log(myTrozo)显示我需要的但我不知道如何管理它返回myTrozo。 任何有经验的人都可以帮助我,如果有什么事情做错了。 感谢
答案 0 :(得分:1)
var items = Meteor.subscribe('Calendar');
var itemsCursor = items.find({ status_visualizacion: "visible" });
while ( itemCursor.hasNext() ) {
item = itemCursor.next();
for (i = 0; i < item.calendario_slaves.length; i++) {
console.log(item.calendario_slaves[i]);
}
}
答案 1 :(得分:1)
使用.concat
连接数组。您不需要转换为字符串并拆分。
Template.testeo.helpers({
ls() {
const result=[];
Calender.find({status_visualizacion: "visible"}).forEach(e => {
if ( e.calendario_slaves && e.calendario.slaves.length ){ // guard against missing/empty
results.concat(e.calendario_slaves);
}
});
return result;
}
});