node实践操作二

来源:luqidong 发布时间:2013-08-05 20:02:10 点击数:

    也许你会看到官网的一个demo:

var http = require('http');
http.createServer(function (req, res) {
  res.writeHead(200, {'Content-Type': 'text/plain'});
  res.end('Hello World\n');
}).listen(1337, '127.0.0.1');
console.log('Server running at http://127.0.0.1:1337/');
 保存为demo.js 然后cmd  node它 
这个在浏览器里面输入:127.0.0.1:1337 就会在页面显示Hello World的字样,在这里稍微解释下 

var http=require('http');//启用node的http模块 这个就是http协议的最基本的东西(我现在是这样说的,明白就好,貌似说的不太准确)。
http里面有个createServer的方法,这个方法会返回一个对象,
这个对象有一个叫做 listen 的方法,这个方法有一个数值参数,指定这个HTTP服务器监听的端口号。 writeHead中的200意思是返回成功了,后面的是返回的类型,end是结束。这里他结束了就输出个hello world。这样的写法看起来很不爽,当然我看起来很淡定因为jquery这样的写法很普遍,我们换一种写法:
var http = require('http');
function start(request, response) {
  response.writeHead(200, {"Content-Type": "text/plain"});
  response.end("Hello World");
}
http.createServer(start).listen(1337, '127.0.0.1');
console.log('Server running at http://127.0.0.1:1337/');
78OA办公系统
这样看起来是不是好多了。如果你想终止运行这个文件的话,定位客户端按ctrl+c。
我们下面去搞一搞匿名函数,举个例子:
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的第一次亲密接触,不过我们还是得循序渐进。现在,我们先接受这一点:在JavaScript中,一个函数可以作为另一个函数接收一个参数。我们可以先定义一个函数,然后传递,也可以在传递参数的地方直接定义函数。

以上由78oa系统人员整理转载请著名出处