13、Node.js 函数

JavaScript 中的函数是一等公民,一个函数可以作为另一个函数的参数。

我们既可以先定义一个函数,然后作为参数传递给另一个函数,也可以直接在传递参数的地方定义一个匿名函数

因为Node.js 基于 JavaScript ,所以在 Node.js 中定义和使用函数和 JavaScript 中一样

/*
 * filename: main.js
 * author: DDKK.COM 弟弟快看,程序员编程资料站(ddkk.com)
 * Copyright © 2015-2065 ddkk.com. All rights reserved.
*/

function say(word) {
  console.log(word);
}

function execute(someFunction, value) {
  someFunction(value);
}

execute(say, "Hello");

这段代码,我们把 say 函数作为 execute 函数的第一个参数传递

此时,say 函数返回的不是它自己的返回值,而是返回 say 函数本身

这样一来,say 就变成了 execute 中的本地变量 someFunction ,execute 可以通过调用 someFunction() (带括号的形式)来使用 say 函数

因为say 函数需要一个参数, execute 在调用 someFunction 时可以传递这样一个参数

运行以上 Node.js 范例,输出结果如下

$ node main.js
Hello

匿名函数

JavaScript 将函数作为参数进行传递,不一定要遵循 “先定义,再传递” 的原则,可以直接在传递的时候定义函数,这种函数我们称之为 匿名函数

用这种方式,我们甚至不用这种参数函数起名字,这也是为什么它被叫做匿名函数

使用匿名函数,我们可以将上面的范例改写如下

/*
 * filename: main.js
 * author: DDKK.COM 弟弟快看,程序员编程资料站(ddkk.com)
 * Copyright © 2015-2065 ddkk.com. All rights reserved.
*/

function execute(someFunction, value) {
  someFunction(value);
}

execute(function(word){ console.log(word) }, "Hello");

我们在execute 接受第一个参数的地方直接定义了传递给 execute 的函数

运行以上 Node.js 脚本,输出结果如下

$ node main.js
Hello

函数参数传递是如何让 HTTP 服务工作的

使用函数作为参数,我们可以把本来很复杂的逻辑整理的清楚明白

/*
 * filename: main.js
 * author: DDKK.COM 弟弟快看,程序员编程资料站(ddkk.com)
 * Copyright © 2015-2065 ddkk.com. All rights reserved.
*/

var http = require("http");

http.createServer(function(request, response) {
  response.writeHead(200, {"Content-Type": "text/plain"});
  response.write("Hello World");
  response.end();
}).listen(8888);

这段代码使用了匿名函数,而且已经够清楚明白了

当然,我们也可以把上面的代码改写成如下的格式

/*
 * filename: main.js
 * author: DDKK.COM 弟弟快看,程序员编程资料站(ddkk.com)
 * Copyright © 2015-2065 ddkk.com. All rights reserved.
*/

var http = require("http");

function onRequest(request, response) {
  response.writeHead(200, {"Content-Type": "text/plain"});
  response.write("Hello World");
  response.end();
}

http.createServer(onRequest).listen(8888);