Home > Web Front-end > JS Tutorial > body text

Detailed explanation of event processing mechanism in node.js

高洛峰
Release: 2016-12-05 10:59:42
Original
1012 people have browsed it

EventEmitter Class

In the event module of Node.js, which is used to implement various event processing, an EventEmitter class is defined. All objects that may trigger events are instance objects that integrate a subclass of the EventEmitter class. In Node.js, many methods are defined for the EventEmitter class. All processing related to the binding and unbinding of the object's event processing function is Execution relies on calls to these methods.

Various methods of the EventEmitter class

event: represents the event name

listener: represents the event processing function

The parameters in brackets represent that the parameters are optional parameters

Detailed explanation of event processing mechanism in node.js

on method of the EventEmitter class

var http = require("http");
var server = http.createServer();
server.on("request", function(req, res){
 console.log(req.url);
 res.end();
});
server.listen(1337, "127.0.0.1");
Copy after login

In this code, we specify that when the server receives a client request, output the URL address of the target requested by the client in your console window, and use the end method of the response object to end the response immediately .

Execute the code, and then enter: http://localhost:1337:// in the browser window, the console output is as follows:

Detailed explanation of event processing mechanism in node.js

Console output

Of course, you can also use multiple on methods Executed to bind multiple event handlers to the same event. As follows:

var http = require("http");
var server = http.createServer();
 
server.on('request', function(req, res){
 console.log('接收到客户端请求')
})
 
server.on("request", function(req, res){
 console.log('处理客户端请求')
 console.log(req.url);
 res.end();
})
 
server.on('request', function(req, res){
 console.log('发送响应完毕')
})
 
server.listen(1337, "127.0.0.1");
Copy after login
Copy after login

OK, execute the code, and the console output is as follows:

Detailed explanation of event processing mechanism in node.js

Console output

In addition, by default, up to 10 time processing functions can be bound to the same specified event. You can modify the maximum number of event processing functions that can be bound through the setMaxListeners method. The method is as follows:

emitter.setMaxListeners(n)
Copy after login

once method of the EventEmitter class

The once method of the EventEmiiter class is similar to the on method, and its function is to bind the specified event The difference is that when the event processing function is executed once, it is contacted immediately, that is, the event processing function will only be executed once. The parameters used in the once method are the same as those used in the on method, as follows:

emitter.once(event, listener)
Copy after login

Do an experiment.

Or execute the following code (same as above):

var http = require("http");
var server = http.createServer();
 
server.on('request', function(req, res){
 console.log('接收到客户端请求')
})
 
server.on("request", function(req, res){
 console.log('处理客户端请求')
 console.log(req.url);
 res.end();
})
 
server.on('request', function(req, res){
 console.log('发送响应完毕')
})
 
server.listen(1337, "127.0.0.1");
Copy after login
Copy after login

Then, open 127.0.0.1:1337 twice in a row in the browser window, and the console output is as follows:

Detailed explanation of event processing mechanism in node.js

is displayed twice

Then change the on event to once event, the code is as follows:

var http = require("http");
var server = http.createServer();
 
server.once('request', function(req, res){
 console.log('接收到客户端请求')
})
 
server.on("request", function(req, res){
 console.log('处理客户端请求')
 console.log(req.url);
 res.end();
})
 
server.once('request', function(req, res){
 console.log('发送响应完毕')
})
 
server.listen(1337, "127.0.0.1");
Copy after login

The console output is as follows:

Detailed explanation of event processing mechanism in node.js

The request is processed 2 times, and the rest are only printed once!

Use the removeListener method to cancel the event handler

The code is as follows:

var http = require("http");
var server = http.createServer();
var testFunction = function (req,res) {
 console.log('发送响应完毕')
}
 
server.on('request', function(req, res){
 console.log('接收到客户端请求')
})
 
server.on("request", function(req, res){
 console.log('处理客户端请求')
 console.log(req.url);
 res.end();
})
 
server.on('request', testFunction)
//删除
server.removeListener('request', testFunction)
server.listen(1337, "127.0.0.1");
Copy after login

Run the code, enter 127.0.0.1:1337 in the browser window, the console output is as follows

Detailed explanation of event processing mechanism in node.js

Console output

emit method : Customize the event and trigger it

The code is as follows:

var http = require("http");
var server = http.createServer();
 
server.on("request", function(req, res){
 console.log(req.url);
});
 
//自定义事件
server.on("customEvent", function(arg1, arg2, arg3){
 console.log("自定义事件被触发");
 console.log(arg1);
 console.log(arg2);
 console.log(arg3);
});
 
//触发自定义事件
server.emit('customEvent', '自定义参数1', '自定义参数2', '自定义参数3')
server.listen(1337, "127.0.0.1");
Copy after login

This time, instead of entering the address in the browser window, run the code directly to view the console output. The console output is as follows:

Detailed explanation of event processing mechanism in node.js

Console output

Indicates that we manually triggered the custom event, which is customEvent.

Summary

The above is the entire content of this article. I hope the content of this article can be helpful to everyone learning or using node.js


Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!