码迷,mamicode.com
首页 > Web开发 > 详细

Node.js知识点整理之----基础知识----事件处理机制及事件环机制

时间:2018-09-22 12:29:49      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:nbsp   事件处理机制   自定义   情况   mit   div   res   定义   针对   

在event模块中,定义了EventEmitter类,所有触发事件的对象都是继承了这个类的子类的实例对象。

addListener(event,listener)

对指定事件绑定事件处理函数

 

on(event,listener)

对指定事件绑定事件处理函数(addListener方法的别名)

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

参数:

  • event:指定的事件名
  • listener:事件处理函数

可以通过多个on方法的执行来对同一个事件绑定多个事件处理函数。

在默认情况下,针对同一个指定事件,最多可以绑定10个事件处理函数

once(event,listener)

对指定事件指定只执行一次的事件处理函数

 

removeListener(event,listener)

对指定事件解除事件处理函数

 

removeAllListeners([event])

对指定事件解除所有事件处理函数

 

setMaxListeners(n)

指定事件处理函数的最大数量。n为整数

 

listeners(event)

获取指定事件的所有事件处理函数

 

emit(event,[arg1],[arg2],[...])

手工触发指定事件

var http = require(‘http‘);
var server = http.createServer();

server.on(‘custimEvent‘,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‘);

listenerCount(emitter,event)

获取某个对象的指定事件的事件处理函数的数量。

var http = require(‘http‘);
var server = http.createServer();
var events = require(‘events‘);

server.on(‘request‘,function(req,res){
    //...
})

server.on(‘request‘,function(req,res){
    //...
})

server.on(‘request‘,function(req,res){
    //...
})

server.listen(1337,‘127.0.0.1‘);

console.log(events.EvevntEmitter.listenerCount(server,‘‘request));

EventEmitter类自身所拥有的事件

newListener事件:当对象绑定事件处理函数时,都将触发此事件

removeListener事件:当对象取消事件处理函数时,都将触发此事件

 

事件环机制

在一个时刻只能执行一个回调函数,因为在JavaScript中只能使用单线程

在一个应用程序中,需要按照次序处理每个事件,而线程每次只能处理一个回调函数,这时有新事件需要处理时,程序会转而处理新的事件,在处理完新事件之后,再回到原来的事件中继续处理,这就叫事件环机制。

 

Node.js知识点整理之----基础知识----事件处理机制及事件环机制

标签:nbsp   事件处理机制   自定义   情况   mit   div   res   定义   针对   

原文地址:https://www.cnblogs.com/adhehe/p/9689326.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!