nodejs第五节课

2021年11月24日 阅读数:5
这篇文章主要向大家介绍nodejs第五节课,主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。

hello,你们好,我是 nodejs,欢迎你们来到 nodejs 课堂。
今天咱们顺着昨天的课堂上遗留下来的问题node

进行函数传递

咱们先来举个例子服务器

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

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

execute(say, "Hello");

请仔细阅读这段代码!在这里,咱们把 say 函数做为execute函数的第一个变量进行了传递。这里传递的不是 say 的返回值,而是 say 自己!ide

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

固然,由于 say 有一个变量, execute 在调用 someFunction 时能够传递这样一个变量。ui

咱们能够,就像刚才那样,用它的名字把一个函数做为变量传递。可是咱们不必定要绕这个“先定义,再传递”的圈子,咱们能够直接在另外一个函数的括号中定义和传递这个函数:code

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

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

咱们在 execute 接受第一个参数的地方直接定义了咱们准备传递给 execute 的函数。ip

用这种方式,咱们甚至不用给这个函数起名字,这也是为何它被叫作 匿名函数 。it

这是咱们和我所认为的“进阶”JavaScript的第一次亲密接触,不过咱们仍是得按部就班。如今,咱们先接受这一点:在JavaScript中,一个函数能够做为另外一个函数接收一个参数。咱们能够先定义一个函数,而后传递,也能够在传递参数的地方直接定义函数。io

函数传递是如何让HTTP服务器工做的

带着这些知识,咱们再来看看咱们简约而不简单的HTTP服务器:console

var http = require("http");

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

如今它看上去应该清晰了不少:咱们向 createServer 函数传递了一个匿名函数。

用这样的代码也能够达到一样的目的:

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

也许如今咱们该问这个问题了:咱们为何要用这种方式呢?