为了账号安全,请及时绑定邮箱和手机立即绑定

c++怎么异步回调node.js函数

c++怎么异步回调node.js函数

C++
哆啦的时光机 2019-04-04 06:02:34
c++怎么异步回调node.js函数
查看完整描述

3 回答

?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

node.js开发过程中会遇到层层回调,虽然回调是node.js的优势所在,但同样也是坑。有如下场景需要返回多层回调函数中的结果:
http.request("/url", function(res){
obj.get(res, function(res2){
obj.get(res2,function(res3){
//此处可以得到res3
});
});
console.log('结束');
});
假如有一个函数
var func1 = function() {
//在这里会用到上面的那段代码
}
就像下面这样
router.get('url', function(req, res) {
http.request("/url", function(res1) {
obj.get(res, function(res2) {
obj.get(res2,function(res3) {
//得到res3后传值到页面
res.render('html',{res:res3})
});
});
});
});
如果我们有多个路由都需要用到那段代码的返回值,我们或许会把它提取出来当做一个公共的部分来使用,于是把它放到一个函数中:
var func2= function(){
http.request("/url", function(res){
obj.get(res, function(res2){
obj.get(res2,function(res3){
//在此处返回得到的值
returen res3;
});
});
console.log('结束');
});
}
然后在每个路由中调用,可是结果却出人意料,在调用func2()以后并没有得到想要的结果res3,事实上已经输出了“结束”两字。
其实这就是node.js的异步回调导致的结果,整个代码段走完了,回调函数中的值却没有返回。
那该怎么办?解决办法还是用回调解决,将上面代码改写:
var func2= function(param, callback) {
http.request("/url", function(res) {
obj.get(res, function(res2) {
obj.get(res2,function(res3) {
callback(res3);
});
});
console.log('结束');
});
}
接下来就是调用上面这段代码:
router.get("url", function(req, res) {
func2(p1, function(res2) {
res.render("html", {res:res2});
});
});



查看完整回答
反对 回复 2019-04-05
?
慕雪6442864

TA贡献1812条经验 获得超5个赞

拥抱ES6,替代回调函数,解决回调地狱问题

话说EcmaScript Harmony (ES6)给js引入了不少新特性,对ES6不太了解的同学,可以自行百度一下。

在nodejs中使用ES6的新特性,需要用v0.11.x以上的版本才行。

本文介绍的是使用Generator特性替代回调函数,对Generator不了解?可以看看这里。

这里用到了co和thunkify两个模块,大家使用npm install命令安装之。

启动时,为了让nodejs支持ES6的特性,需要附加--harmony参数,如:node --harmony index.js

还是以本文刚开始提到的问题为例,使用generator特性的实例代码如下:

var fs = require('fs')
, co = require('co')
, thunkify = require('thunkify');

var readFile = thunkify(fs.readFile);

co(function *() {
var test1 = yield readFile('test1.txt');
var test2 = yield readFile('test2.txt');
var test = test1.toString() + test2.toString();
console.log(test);
})();

处理代码中的异常也是很简单的,只需要这样就OK了:

try {
var test1 = yield readFile('test1.txt');
} catch (e) {
// 在这里处理异常
}



查看完整回答
反对 回复 2019-04-05
  • 3 回答
  • 0 关注
  • 1013 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信