2

我正在尝试从构造函数调用类中的生成器函数,它运行但没有任何反应(我的 console.log 没有打印),就好像从未调用过生成器函数一样。

更新#1:

这是我的代码的更新版本。我可以使用 next() 函数访问我的 findOne 函数,但是因为我用 co-monk 包装了“用户”,所以我很难没有必要调用它。我仍然不确定为什么我需要调用 next(0) 函数 2 次才能跳过 yield 调用。

因此,当我打印“userData”的输出时,我现在变得不确定。

如果我的问题与了解产量的工作原理有关,那么指出我的方向可能会对我有所帮助。我尝试将生成器函数与类之外的 yield 调用一起使用,并且它与僧侣/合僧侣一起工作得很好。

更新#2:

我还应该提到我正在使用 babel6 进行成绩单。

"use strict";

var monk = require("monk");
var wrap = require("co-monk");
var db = monk("localhost/test");
var users = wrap(db.get("users"));

class User {

    constructor(user) {
        if (typeof user == "object") {

            var findUser = this.findOne(user.id);
            findUser.next();
            findUser.next();

            if(findUser != null){
                this._user = user;
            }

        }
        else {
            console.error("user parameter is not an oject");
            return false;
        }
    }

    *findOne(id) {

        var userData = yield users.findOne({_id: id});

        console.log(userData); // Getting undefined

        this._user = userData;

    };


}

var _user = new User({id : "1234"});
console.log(_user);

export default User;
4

2 回答 2

4

看起来文档co-monk有点含糊,但看看它拥有的一个测试,它需要在co.

var co = require("co");

// rest of your code

  findOne(id) {
    return co(function* () {
      var userData = yield users.findOne({_id: id});
      console.log(userData); // Getting undefined
      this._user = userData;
    });
  };

它不允许您做的是将异步代码无缝转换回同步代码,因此this.findOne()将返回一个承诺。因此,您的User对象可能不会在调用后立即填充new User({id : "1234"})

于 2016-01-10T18:54:12.287 回答
0

尝试使用 lib co 并且它有效。

看起来 co-monk 目前在一个类的生成器函数中被破坏了。

所以这对我有用:

"use strict";

var monk = require("monk");
//var wrap = require("co-monk");
var db = monk("localhost/test");
var users = (db.get("users"));
var co = require('co');

class User {

    constructor(user) {
        if (typeof user == "object") {
            var findUser = this.findOne(user.id);
            this._user = user;
        }
        else {
            console.error("The user params is not an object");
        }
    }

    findOne(id) {

        co(function* () {
            return yield users.findOne({_id: id});
        }).then(function (val) {
            console.log(val);
        }, function (err) {
            console.error(err.stack);
        });

    };
}
于 2016-01-09T06:35:08.927 回答