koa - promise then里面使用return的疑问?
本文介绍了koa - 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,也能渲染页面?
解决方案
当只有一条语句例如 () => co(this.render('user', data))
时,等价于
function (){ return co(this.render('login', data));}
当 ()=>{} {}内有多条语句,须加return
这篇关于koa - promise then里面使用return的疑问?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文