返回游标数组不会显示任何结果

时间:2014-04-10 17:15:10

标签: javascript mongodb meteor

我试图通过这样做来解决两个集合的“连接”:

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

1 个答案:

答案 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,每次用户更改时都会重绘整个列表。