前言:
nodeJS最大的特点就是其异步操作,其后边方法的执行不会等到前边方法执行完才去运行,而是同时执行好几个方法,这种方式在给我们提高效率的同时也给开发多多少少带来了不便,有时候我们不要求有这种效果的出现,这时候就需要进行去异步操作。
node的去异步方式主要有三种:方法嵌套,递归调用,调用类库
【实例代码】
var func1 = function(req,res,callback){
setTimeout(function(){
console.log('执行 func1');
callback(req,res,1);
},13000);
}
var func2 = function(req,res,callback){
setTimeout(function(){
console.log('执行 func2');
callback(req,res,2);
},5000);
}
var func3 = function(req,res,callback){
setTimeout(function(){
console.log('执行 func3');
callback(req,res,3);
},1000);
}
#可以看出在func1,func2和func3中都是用了setTimeout函数,执行的时间分别为13秒,5秒和1秒。由于nodejs异步的特性,如果使用普通的函数调用方法:
var req = null;
var res = null;
var callback = function(){};
func1(req,res,callback);
func2(req,res,callback);
func3(req,res,callback);
#打印结果(异步结果)
执行 func3
执行 func2
执行 func1
#原因是因为nodejs是异步的,func2不会等func1执行完毕后再执行,而是立即执行(func3也是如此)。由于func3的运行时间最短而率先结束,func2次之,func1最后。但这明显不是我们想要的结果。怎么办?
【处理去除异步效果】
(1):方法嵌套
var req = null;
var res = null;
func1(req,res,function(){
func2(req,res,function(){
func3(req,res,function(){
process.exit(0);
})
});
});
#这种方法虽然能快速的解决,但暴露的问题也很明显,一是代码维护不方面,二是代码的深层嵌套看起来很不舒服。这种方法并不可取。
嵌套处理异步实例:
(2):递归调用
function executeFunc(funcs,count,sum,req,res){
if(count == sum){
return ;
}else{
funcs[count](req,req,function(){
count++;
executeFunc(funcs,count,sum,req,res);
});
}
}
//同步调用
var req = null;
var res = null;
var funcs = [func1,func2,func3];
var len = funcs.length;
executeFunc(funcs,0,len,req,res);
#先将多个函数组成一个数组。再可以利用递归函数的特性,使程序按照一定的顺序执行。
(3):调用类库 Step和async
#随着nodejs的发展,响应的类库也越来越多。Step和async 就是其中不错的。
# 方式一: Step实现 即用step方法将要实现同步的方法包裹起来
Step(
function thefunc1(){
console.log(finishFlag);
func1(this);
},
function thefunc2(finishFlag){
console.log(finishFlag);
func2(this);
},
function thefunc3(finishFlag){
console.log(finishFlag);
func3(this);
}
);
# 方式二:async实现 其本质是使用async 的 series方法实现
var req = null;
var res = null;
var callback = function(){};
async.series(
[
function(callback){
func1(req,res,callback);
},
function(callback){
func2(req,res,callback);
},
function(callback){
func3(req,res,callback);
}
]
);