我试图通过这样做来解决两个集合的“连接”:
foundUsers: function()
{
var searchUser = Session.get("searchUser"); // user search criteria
var usf = User.find(searchUser, {}); // get user results
var typeId = usf.map(function(p) { return p.us_ut_id }); // get type ids
var tyf = Type.find({_id: {$in: typeId}}, {}); // new Meteor.Collection.ObjectID("533d63bef0e236f9d76db905")
var typeName = tyf.map(function(p) { return p.ut_name.toString() }); // check type names
console.log(typeName);
return [usf, tyf];
}
我的html字段中的结果只是空白字段而没有错误消息,所以我做得不对?
这一点是使用typeId中的_id数字来获取以html格式显示的正确用户类型。
返回usf; //这将返回所有没有类型的用户
返回tyf; //这会返回没有用户的所有类型
更新1:
模板看起来像这样:
<template name="getResult">
{{#each foundUsers}}
<input type="text" id="firstname" value="{{us_firstname}}"/><br>
<input type="text" id="lastname" value="{{us_lastname}}"/><br>
<input type="text" id="typename" value="{{us_ut_name}}"/><br>
{{/each}}
</template>
us_xxx应该找到名称等用户数据。 us_ut_name应该显示我们从us_ut_type获得的ObjectID所获得的类型的名称。
更新2:
所以我创建了这样的代码,我相信它应该可以工作,因为它在控制台中打印了正确的数据:
// display user data
Template.getResult.helpers(
{
foundUsers: function()
{
var selector = Session.get('searchUser');
var users = User.find(selector).fetch();
return _.each(users, function(user)
{
console.log(user);
var result = user.us_ut_name = Type.findOne({_id: new Meteor.Collection.ObjectID(user.us_ut_id._str)}).ut_name;
console.log(user.us_firstname + ", " + result);
return result;
});
}
});
但结果未显示在页面上。
这打印例如:
约翰,理发师 迈克,木匠 巴克,狗
在控制台中,但不在网站的输入字段中。
SOLUTION:
Template.getResult.helpers(
{
foundUsers: function()
{
var selector = Session.get('searchUser');
var users = User.find(selector).fetch();
_.each(users, function(user)
{
console.log(user);
var result = user.us_ut_name = Type.findOne({_id: new Meteor.Collection.ObjectID(user.us_ut_id._str)}).ut_name;
console.log(user.us_firstname + ", " + result);
return result;
});
return users;
}
});
谢谢David Weldon
答案 0 :(得分:1)
如果我理解你的模型,这可能会有效:
foundUsers: function() {
var selector = Session.get('searchUser');
var users = User.find(selector).fetch();
_.each(users, function(user) {
return user.tyf_type = Type.findOne(user.us_ut_id).ut_name.toString();
});
return users;
}
它使用给定的选择器获取用户,然后通过添加tyf_type
属性修改每个用户。唯一的缺点是它使用fetch
,每次用户更改时都会重绘整个列表。