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);