promise then里面使用return的疑问?

//1
exports.login = function* (){
    let data = {config};
    let req = this.request.body;
    let loginname = req.loginname;
    let password = md5(req.password);

    yield Promise.resolve()
    .then(() => User.findOne({loginname: loginname}))
    .then((user) => {
        if(user && (password === user.password)){
            this.session.loginname = loginname;
            this.redirect('/');
        }else{
            data.errMsg = 'please check name & password';
            return co(this.render('login', data));
        }
    });
};

//2
exports.userInfo = function* (){
    let loginname = this.params.loginname;
    let data = {
            config,
            user: this.session.user
        };

    yield Promise.resolve()
    .then(() => User.findOne({loginname: loginname}))
    .then((user) => {data.userintro = user;})
    .then(() => co(this.render('user', data)))
};

这是使用koa编写的两端代码,为何同样是then里面写的函数,一个需要return,而另一个不需要return,也能渲染页面?

阅读 6.3k
2 个回答

当只有一条语句例如 () => co(this.render('user', data)) 时,等价于

function (){ return co(this.render('login', data));}

当 ()=>{} {}内有多条语句,须加return

() => someobj

等价于

function () {return someobj}
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进