Node.js入门学习笔记(二)
2015-05-08 17:35
676 查看
函数传递
举例来说,你可以这样做:
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时可以传递这样一个变量。
我们可以就像刚才那样,用它的函数名字把一个函数作为参数传递。但是我们不一定要绕这个‘先定义,再传递’的圈子,我们可以直接在另一个函数的括号中定义和传递这个函数。
function execute(someFunction, value) {
someFunction(value);
}
execute(function(word){console.log(word) }, "Hello");我们在execute接受第一个参数的地方直接定义了我们准备传递给execute的函数。用这种方式,我们甚至不用给这个函数起名字,这也是为什么它被叫做匿名函数。
在Javascript中,一个函数可以作为另一个函数的一个参数,我们可以先定义一个函数,然后传递,也可以在传递参数的地方直接定义函数。
函数传递是如何让HTTP服务器工作的
带着这些知识,我们再来看看我们简约而不简单的HTTP服务器:
var http = require("http");
http.createServer(function(request, response) {
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World"); response.end();
}).listen(8888);
现在它看上去应该清晰了很多:我们向 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(8888);
举例来说,你可以这样做:
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时可以传递这样一个变量。
我们可以就像刚才那样,用它的函数名字把一个函数作为参数传递。但是我们不一定要绕这个‘先定义,再传递’的圈子,我们可以直接在另一个函数的括号中定义和传递这个函数。
function execute(someFunction, value) {
someFunction(value);
}
execute(function(word){console.log(word) }, "Hello");我们在execute接受第一个参数的地方直接定义了我们准备传递给execute的函数。用这种方式,我们甚至不用给这个函数起名字,这也是为什么它被叫做匿名函数。
在Javascript中,一个函数可以作为另一个函数的一个参数,我们可以先定义一个函数,然后传递,也可以在传递参数的地方直接定义函数。
函数传递是如何让HTTP服务器工作的
带着这些知识,我们再来看看我们简约而不简单的HTTP服务器:
var http = require("http");
http.createServer(function(request, response) {
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World"); response.end();
}).listen(8888);
现在它看上去应该清晰了很多:我们向 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(8888);
相关文章推荐
- Node.js学习笔记-入门
- Node.js入门学习笔记-IDE选择/配置之WebStorm(windows)
- Node.js入门学习笔记-IDE选择/配置之WebStorm(windows)
- Node.js入门学习笔记(三)
- Node.js学习笔记之一:入门
- Node.js入门学习笔记(一)
- Node.js入门学习笔记-IDE选择/配置之WebStorm(windows)
- Node.js学习笔记【1】入门(服务器JS、函数式编程、阻塞与非阻塞、回调、事件、内部和外部模块)
- Node.js入门学习笔记-IDE选择/配置之WebStorm(windows)
- node.js学习笔记(3)_极客学院_服务器入门
- Node.js学习笔记4【核心模块--fs】
- Node.js学习笔记之三:事件_EventEmitter
- Node.js学习笔记
- node.js入门学习
- node.js 学习笔记001 :Hello,world !
- cocos creator学习笔记2017.2.10(node.Js,网络篇)
- node.js学习笔记
- node.js入门学习
- 创业笔记-Node.js入门之基于事件驱动的回调
- Node.js入门笔记