1

我正在尝试使用新 API 操作通过 Deepstream 发送回客户端的数据dataTransforms,但是,我总是进入Uncaught SyntaxError: Unexpected end of input控制台。为 Deepstream 进行数据库查找可能需要很长时间,但我不太确定。

我的相关代码是:

DSServer.set('dataTransforms', [
  {
    topic: DSServer.constants.TOPIC.RECORD,
    action: DSServer.constants.ACTIONS.READ,
    transform: transformRecord
  }
]);

var transformRecord = function (data, metadata) {
  if (metadata.recordName.split('/')[0] === 'team') {
    var new_member_info = [];
    var i = 0;

    _.forEach(data.members, function (members) {
      r.table('user').get(members.user_id).run()
        .then(function (doc) {
          if (doc !== null) {
            new_member_info.push({
              user_id: members.user_id,
              display_name: doc._d.display_name,
              username: doc._d.username
            });

            i += 1;

            if (i === data.members.length) {
              data.members = new_member_info;
              return data;
            }
          }
        })
        .error(function (err) {
          console.error(err);
        });
    });
  } else {
    return data;
  }
};

每当从 RECORD 中读取时,它都会检查它是否是从团队记录中读取的。如果是从团队记录中读取,它将获取属于该团队的所有成员并将其添加到成员:{}。

当它遍历所有成员并添加有关它们的信息时,它将返回新数据。

那么,知道可能出了什么问题吗?

我理解dataTransforms错了吗?

4

1 回答 1

2

出于性能原因,所有数据转换都应同步返回结果。

r.table('user').get(members.user_id).run()
        .then(...

但是异步运行并将其值返回给 中使用的函数then,而不是 dataTransform 函数。无论是否应用了转换,始终返回数据也很重要。

如果我理解正确,您的用例是从 RethinkDb 服务器为多个用户加载信息。我是否可以建议为此用例使用记录名称列表,或者构建一个数据提供程序来与 RethinkDb 交互。

于 2015-07-21T14:50:15.207 回答