Node.js 函数
JavaScript 中的函数是一等公民,一个函数可以作为另一个函数的参数。
我们既可以先定义一个函数,然后作为参数传递给另一个函数,也可以直接在传递参数的地方定义一个匿名函数
因为 Node.js 基于 JavaScript ,所以在 Node.js 中定义和使用函数和 JavaScript 中一样
/* * filename: main.js * author: 简单教程(www.twle.cn) * Copyright © 2015-2065 www.twle.cn. 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: 简单教程(www.twle.cn) * Copyright © 2015-2065 www.twle.cn. 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: 简单教程(www.twle.cn) * Copyright © 2015-2065 www.twle.cn. 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: 简单教程(www.twle.cn) * Copyright © 2015-2065 www.twle.cn. 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);