在async方法完成之前返回的函数
Function returning before async method done Node JS
我现在有一个从路由器调用的函数:
router.js:
var result = Api.getUser();
console.log("Result: " + result);
api.js
exports.getUser = function(req, result) {
request.get({
uri: URL + '/user/me/',
headers: {Authorization: 'bearer ' + req.user.accessToken},
json: true
}, function(e, r, body) {
console.log("e: " + e + " body: %j", body);
if(e) {
return "{error: true}";
} else {
return body;
}
});
};
我遇到的问题是,我首先得到的日志"结果:未定义"。
是否有一种方法来保持函数getUser从返回直到函数get完成?
承诺是很棒的,我建议仔细研究一下。然而,一个简单的回调就可以达到这个目的
api:exports.getUser = function(req, result, callback) {
request.get({
uri: URL + '/user/me/',
headers: {Authorization: 'bearer ' + req.user.accessToken},
json: true
}, function(e, r, body) {
if(e) {
callback({error: true});
} else {
callback(body)
}
});
};
路由器:
var result
Api.getUser(req, result, function (response) {
result = response
console.log(result)
});
您正在处理异步代码。有几种方法可以解决这个问题。
With A Promise
// api.js
var Promise = require('bluebird');
var request = require('request');
var getP = Promise.promisify(request.get.bind(request));
exports.getUser = function(accessToken) {
return getP({
uri: URL + '/user/me/',
headers: {Authorization: 'bearer ' + accessToken},
json: true
}).spread(function(e, r, body) {
console.log("e: " + e + " body: %j", body);
if(e) {
return Promise.reject("{error: true}");
} else {
return Promise.resolve(body);
}
});
};
// main.js
api.getUser(req.user.accessToken)
.then(console.log.bind(console, "Result: "))
.catch(console.error.bind(console));
带回调
// api.js
var request = require('request');
exports.getUser = function(accessToken, callback) {
request.get({
uri: URL + '/user/me/',
headers: {Authorization: 'bearer ' + accessToken},
json: true
}, function(e, r, body) {
console.log("e: " + e + " body: %j", body);
if(e) {
callback("{error: true}");
} else {
callback(null, body);
}
});
};
// main.js
api.getUser(req.user.accessToken, function (err, result) {
if (err) return console.error(err);
console.log("Result: " + result);
});
promise API的好处是,您只需要在最终的.catch
处理程序中检查一次错误。在回调风格中,如果你需要继续进行额外的异步调用,那么你将不得不在每个回调中保持嵌套回调并检查if (err) return console.error(err)
。
你不能从异步函数return
,你使用回调:
exports.getUser = function(req, result, callback) {
request.get({
uri: URL + '/user/me/',
headers: {Authorization: 'bearer ' + req.user.accessToken},
json: true
}, function(e, r, body) {
if(e) {
callback({error: true});
} else {
callback(body);
}
});
};
Api.getUser(req, result, function(user) {
console.log(user);
});
相关文章:
- 使用返回函数sinde.attr()jquery元素
- 从自执行函数返回函数的Javascript性能命中率
- Node Express Handlebars帮助程序未返回函数的结果
- 未在Firefox中执行PageMethod的返回函数
- 对返回函数的函数感到困惑
- 从承诺返回不返回函数会导致警告
- 从函数返回函数而不调用返回的函数
- Javascript,闭包中的返回函数如何与外部函数连接
- 为什么Coderbyte.com's的Javascript模板喜欢返回函数的原始参数
- 对象函数返回函数而不是值
- 从外部函数(数组)了解返回函数(x)
- 从Javascript类对象返回函数
- 调用Typescript setter don't返回函数,尽管关联的getter可以工作
- 使用依赖注入在 JavaScript 中返回函数
- 通过单击JSP和javascript加载两个返回函数
- 需要说明:无法理解返回函数的javascript
- 简单的onClick返回函数不起作用
- 为什么这个闭包返回函数
- JS函数返回函数供以后使用-未定义参数
- Coffeescription类中的方法返回函数而不是字符串