Nodejs异步回调的优雅处理方法
前言
Nodejs最大的亮点就在于事件驱动,非阻塞I/O模型,这使得Nodejs具有很强的并发处理能力,非常适合编写网络应用。在Nodejs中大部分的I/O操作几乎都是异步的,也就是我们处理I/O的操作结果基本上都需要在回调函数中处理,比如下面的这个读取文件内容的函数:
fs.readFile('/etc/passwd',function(err,data){ if(err)throwerr; console.log(data); });
那,我们读取两个文件,将这两个文件的内容合并到一起处理怎么办呢?大多数接触js不久的人可能会这么干:
fs.readFile('/etc/passwd',function(err,data){ if(err)throwerr; fs.readFile('/etc/passwd2',function(err,data2){ if(err)throwerr; //在这里处理data和data2的数据 }); });
那要是处理多个类似的场景,岂不是回调函数一层层的嵌套啊,这就是大家常说的回调金字塔或回调地狱(http://callbackhell.com/)的问题,也是让js小白最为头疼的问题。
这种层层嵌套的代码给开发带来了很多问题,主要体现在:
1.代码可能性变差
2.调试困难
3.出现异常后难以排查
本文主要是介绍如何优雅的处理以上异步回调问题。
初级方案:通过递归处理异步回调
我们可以使用递归作为代码的执行控制工具。把需要执行的操作封装到一个函数中,在回调函数中通过递归调用控制代码的执行流程,废话不多说,上个代码吧:
varfs=require('fs'); //要处理的文件列表 varfiles=['file1','file2','file3'];
functionparseFile(){ if(files.length==0){ return; } varfile=files.shift(); fs.readFile(file,function(err,data){ //这里处理文件数据 parseFile(); //处理完毕后,通过递归调用处理下一个文件 }); }
//开始处理 parseFile();