首页 > 网站 > WEB开发 > 正文

Node.js入门学习笔记(二)

2024-04-27 14:09:42
字体:
来源:转载
供稿:网友

Node.js入门学习笔记(二)

函数传递

举例来说,你可以这样做:

functionsay(Word){console.log(word);}functionexecute(someFunction,value){someFunction(value);}execute(say,"Hello");

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

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

当然,因为say有一个变量,execute在调用someFunction时可以传递这样一个变量。

我们可以就像刚才那样,用它的函数名字把一个函数作为参数传递。但是我们不一定要绕这个‘先定义,再传递’的圈子,我们可以直接在另一个函数的括号中定义和传递这个函数。

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

我们在execute接受第一个参数的地方直接定义了我们准备传递给execute的函数。用这种方式,我们甚至不用给这个函数起名字,这也是为什么它被叫做匿名函数。

javascript中,一个函数可以作为另一个函数的一个参数,我们可以先定义一个函数,然后传递,也可以在传递参数的地方直接定义函数。

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

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

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

现在它看上去应该清晰了很多:我们向 createServer 函数传递了一个匿名函数。

用这样的代码也可以达到同样的目的:

varhttp=require("http");functiononRequest(request,response){response.writeHead(200,{"Content-Type":"text/plain"});response.write("HelloWorld");response.end();}http.createServer(onRequest).listen(8888);


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表