《Node.js》之事件处理机制以及事件环机制(一)

1、Node.js中的事件

Node.js中的JavaScript与运行在浏览器中的JavaScript类似,在程序执行的时候也会触发一些事件,例如:“服务器接收到客户端的请求”,“运行产生错误”,“断开连接”等事件。在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');

程序运行截图: 图片1.png

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');

程序运行截图: 图片2.png

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');

转载于:https://my.oschina.net/u/3346420/blog/1923636

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值