《Node.js》之事件处理机制

1、Node.js中的事件

Node.js中的JavaScript与运行在浏览器中的JavaScript类似,在程序执行的时候也会触发一些事件,例如:“服务器接收到客户端的请求”,“运行产生错误”,“断开连接”等事件。在Node.js中会根据不同的事件,进行相应的处理。

《Node.js》之事件处理机制

2、EventEmitter类

Node.js中的event模块是用于处理各种事件的模块。在event模块中定义了EventEmitter类,所有可以触发事件的对象,都是继承了EventEmitter类的子类的实例对象。在EventEmitter类中定义了很多与对象的事件处理函数绑定和解除相关处理需要用到的方法。

3、EventEmitter类中的方法

on()方法和addListener()方法

on()方法和addListener()方法的功能和内部实现过程是相同的,只是方法名称不同。这两个方法都可以用来为指定的事件名称绑定事件处理函数。使用on()方法绑定事件,程序示例:

var http = require('http');	//引入http模块
var server = http.createServer(); //通过createServer()方法创建http服务器
/*
*为server服务器在接收到来自客户端请求时触发的request事件绑定事件处理函数
*/
server.on('request', function(request, response){
console.log('使用on()方法绑定事件:');
console.log(request.url);
response.end();
});
server.listen(8000, '127.0.0.1');

使用addListener()方法绑定事件,程序示例:

var http = require('http');	//引入http模块
var server = http.createServer(); //通过createServer()方法创建http服务器
/*
*为server服务器在接收到来自客户端请求时触发的request事件绑定事件处理函数
*/
server.on('request', function(request, response){
/*
*使用addListener()方法绑定事件
*/
server.addListener('request', function(request, response){
console.log('使用addListener()方法绑定事件:');
console.log(request.url);
response.end();
});
});
server.listen(8000, '127.0.0.1');

在实际开发过程中可以使用on()方法给一个事件绑定多个不同的事件处理函数,程序示例:

var http = require('http');
var server = http.createServer();
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('服务器端接收到客户端的请求。');
}
});
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log(request.url);
}
response.end();
});
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('发送响应完毕。');
}
response.end();
});

server.listen(8000, '127.0.0.1');

程序运行截图:

《Node.js》之事件处理机制

once()方法

once()与on()方法类似,也可以为指定的事件名称绑定事件处理函数,但是使用once()方法为指定的事件名称绑定事件处理函数只绑定一次。程序示例:

var http = require('http');
var server = http.createServer();
//使用once()方法让绑定的事件函数只执行一次
server.once('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('服务器端已经接收到客户端请求。');
}
});
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log(request.url);
}
response.end();
});
//使用once()方法让事件处理函数只执行一次
server.once('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('发送响应完毕。');
}
});
server.listen(8000, '127.0.0.1');

程序运行截图:

《Node.js》之事件处理机制

removeListener()方法

使用removeListener()方法可以移除指定事件名称的事件处理函数。使用removeListener()方法移除指定事件的事件处理函数,程序示例:

var http = require('http');
var server = http.createServer();
var testFunction = function(request, response){
if(request.url !== '/favicon.ico'){
console.log('发送响应完毕。');
}
}
//为request事件绑定多个事件处理函数
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('接收到客户端的请求。');
}
});
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log(request.url);
}
response.end();
});
server.on('request', testFunction);
server.removeListener('request', testFunction);
server.listen(8000, '127.0.0.1');

removeAllListeners()方法

removeAllListeners()方法可以移除指定事件名称的所有已经绑定事件。程序示例:

var http = require('http');
var server = http.createServer();
var testFunction = function(request, response){
if(request.url !== '/favicon.ico'){
console.log('发送响应完毕。');

}
}
//为request事件绑定多个事件处理函数
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('接收到客户端的请求。');
}
});
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log(request.url);
}
response.end();
});
server.on('request', testFunction);
server.removeAllListener('request');
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log('Hello.');
}
response.end();
});
server.listen(8000, '127.0.0.1');

emit()方法

emit()方法可以用于手动触发一个事件,emit()方法中可以有一个或者多个参数,第一个参数表示被手动触发的事件名称,从第二个参数开始表示传递给事件处理函数的参数。程序示例:

var http = require('http');
var server = http.createServer();
server.on('request', function(request, response){
if(request.url !== '/favicon.ico'){
console.log(request.url);
}
response.end();
});
server.on('myEvent', function(arg1, arg2, arg3){
console.log('自定义事件被触发。');

console.log(arg1);
console.log(arg2);
console.log(arg3);
});
server.emit('myEvent', 'Hello', 'World', '.');
server.listen(8000, '127.0.0.1');

对前端的技术,架构技术感兴趣的同学关注我的头条号,并在后台私信发送关键字:“前端”即可获取免费的架构师学习资料

知识体系已整理好,欢迎免费领取。还有面试视频分享可以免费获取。关注我,可以获得没有 的架构经验哦!!


分享到:


相關文章: