Node所针对的应用程序有一个专门的简称:DIRT。它表示数据密集型实时(data-intensive real-time)程序
简单的异步程序
下面是用文件系统( fs )模块从硬盘中 加载resource.json
这段程序要从硬盘里读取resource.json文件。当所有数据都读出来后,会调用那个匿名函数 (即“回调函数”),传给它的参数是 er (如果出现错误)和 data (文件中的数据)。
Hello World HTTP服务器
Node常被用来构建服务器。有了Node,创建各种服务器变得非常简单。我过去习惯于 把程序部署到服务器中运行(比如把PHP程序放到Apache HTTP服务器上),可能会觉得这种方式 很怪异。在Node中,服务器和程序是一样的。
下面是个简单的HTTP服务器实现,它会用“Hello World”响应所有请求:
只要有请求过来,它就会激发回调函数 function (req, res) ,把“Hello World”写入到 响应中返回去。这个事件模型跟浏览器中对 onclick 事件的监听类似。在浏览器中,点击事件随 时都可能发生,所以要设置一个函数来执行对事件的处理逻辑,而Node在这里提供了一个可以随 时响应请求的函数。
下面是同一服务器的另一种写法,这样看起来 request 事件更明显:
流数据
用数据流的方 式来处理resource.json:
只要有新的数据块准备好,就会激发 data 事件,当所有数据块都加载完之后,会激发一个 end 事件。
Node中也有可写数据流,可以往里写数据块
如何把一张图片流到客户端:
数据从文件中读进来( fs.createReadStream ),然后数据随着进来就被 送到( .pipe )客户端( res )。在数据流动时,事件轮询还能处理其他事件