Node.js EventEmmitter事件监听器用法实例分析


Posted in Javascript onJanuary 07, 2019

本文实例讲述了Node.js EventEmmitter事件监听器用法。分享给大家供大家参考,具体如下:

Node.js 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列。

events 模块只提供了一个对象: events.EventEmitter。EventEmitter 的核心就是事件触发与事件监听器功能的封装。
该模块已被node.js默认引,不需要使用require()显示引入。

EventEmitter 对象如果在实例化时发生错误,会触发 ‘error' 事件。当添加新的监听器时,'newListener' 事件会触发,当监听器被移除时,'removeListener' 事件被触发。

一、on(event, listener)

为指定事件注册一个监听器,接受一个字符串 event 和一个回调函数。

var myEvent = new events.EventEmitter();
var listener = function() {
  console.log('someEvent emit');
}
myEvent.on('someEvent', listener);
//这里是lambda表达式
setTimeout(() => myEvent.emit('someEvent'), 1000);

EventEmitter 的每个事件由一个事件名和若干个参数组成,事件名是一个字符串,通常表达一定的语义。对于每个事件,EventEmitter 支持 若干个事件监听器。
当事件触发时,注册到这个事件的事件监听器被依次调用,事件参数作为回调函数参数传递。

var myEvent = new events.EventEmitter();
myEvent.on('someEvent', function(arg1,arg2) { console.log('someEvent 1 emit', arg1, arg2);});
myEvent.on('someEvent', (arg1,arg2) => console.log('someEvent 2 emit', arg1, arg2));
myEvent.emit('someEvent', 'arg1', 'arg2');
/*
输出
someEvent 1 emit arg1 arg2
someEvent 2 emit arg1 arg2
*/

二、once(event, listener)

为指定事件注册一个单次监听器,即 监听器最多只会触发一次,触发后立刻解除该监听器。

var myEvent = new events.EventEmitter();
myEvent.once('someEvent', function () {
  console.log('someEvent emit');
});
myEvent.emit('someEvent');
/*
返回 true
输出 someEvent emit
*/
myEvent.emit('someEvent');
//返回 false

三、removeListener(event, listener)

移除指定事件的某个监听器,监听器必须是该事件已经注册过的监听器。

var myEvent = new events.EventEmitter();
var listener = () => console.log('someEvent emit');
myEvent.on('someEvent', listener);
myEvent.removeListener('someEvent', listener);
myEvent.emit('someEvent');
//返回 false

四、removeAllListeners([event])

移除所有事件的所有监听器, 如果指定事件,则移除指定事件的所有监听器。

五、setMaxListeners(n)

默认情况下, EventEmitters 如果你添加的监听器超过 10 个就会输出警告信息。 setMaxListeners 函数用于提高监听器的默认限制的数量。

六、listenerCount(emitter, event)

返回指定事件的监听器数量。

var myEvent = new events.EventEmitter();
myEvent.listenerCount();
//输出 0
events.EventEmitter.listenerCount(myEvent);
//输出 0
events.EventEmitter.listenerCount(myEvent, 'someEvent');
//输出 0
myEvent.on('someEvent', () => console.log('someEvent emit'));
myEvent.listenerCount();
//输出 0
events.EventEmitter.listenerCount(myEvent);
//输出 0
events.EventEmitter.listenerCount(myEvent, 'someEvent');
//输出 1

七、error 事件

EventEmitter 定义了一个特殊的事件 error,它包含了错误的语义,我们在遇到 异常的时候通常会触发 error 事件。
当 error 被触发时,EventEmitter 规定如果没有响 应的监听器,Node.js 会把它当作异常,退出程序并输出错误信息。
我们一般要为会触发 error 事件的对象设置监听器,避免遇到错误后整个程序崩溃。

var myEvent = new events.EventEmitter();
myEvent.on('uncaughtException', (err) => {
 console.log('whoops! there was an error');
});
myEvent.emit('error', new Error('whoops!'));
//输出 Error: whoops!
myEvent.on('error', (err) => {
 console.log('whoops! there was an error');
});
myEvent.emit('error', new Error('whoops!'));
//输出 whoops! there was an error

注意

大多数时候我们不会直接使用 EventEmitter,而是在对象中继承它。包括 fs、net、 http 在内的,只要是支持事件响应的核心模块都是 EventEmitter 的子类。

为什么要这样做呢?原因有两点:

1. 具有某个实体功能的对象实现事件符合语义, 事件的监听和发射应该是一个对象的方法。
2. JavaScript 的对象机制是基于原型的,支持 部分多重继承,继承 EventEmitter 不会打乱对象原有的继承关系。

Events(事件)模块是Node.js的核心,许多其他模块用它来围绕着事件架构功能。由于Node.js运行在单一的线程中,任何同步代码都是阻塞的,所以如果有长时间运行的代码的话事件循环便会被阻塞。为了有效地使用Node.js编写代码,必须仔细思考自己的变成风格并遵循一些简单的规则。

  • 别阻塞——Node.js是单线程的,如果代码阻塞的话所有其他的一切都会停止。
  • 快速返回——操作应当快速返回。如果不能快速返回,就应道将其移到另一个进程中。

希望本文所述对大家nodejs程序设计有所帮助。

Javascript 相关文章推荐
javascript 学习之旅 (3)
Feb 05 Javascript
myeclipse安装jQuery插件的方法
Mar 29 Javascript
javascript动态创建表格及添加数据实例详解
May 13 Javascript
javascript中对变量类型的判断方法
Aug 09 Javascript
如何利用AngularJS打造一款简单Web应用
Dec 05 Javascript
利用Query+bootstrap和js两种方式实现日期选择器
Jan 10 Javascript
利用js判断手机是否安装某个app的多种方案
Feb 13 Javascript
原生JS实现小小的音乐播放器
Oct 16 Javascript
layui 优化button按钮和弹出框的方法
Aug 15 Javascript
webpack4 升级迁移的实现
Sep 12 Javascript
使用Webpack提升Vue.js应用程序的4种方法(翻译)
Oct 09 Javascript
基于Angular 8和Bootstrap 4实现动态主题切换的示例代码
Feb 11 Javascript
小程序二次贝塞尔曲线实现购物车商品曲线飞入效果
Jan 07 #Javascript
jQuery实现的别踩白块小游戏完整示例
Jan 07 #jQuery
jQuery判断自定义属性data-val用法示例
Jan 07 #jQuery
jQuery实现的简单歌词滚动功能示例
Jan 07 #jQuery
微信小程序发送短信验证码完整实例
Jan 07 #Javascript
JS数组求和的常用方法实例小结
Jan 07 #Javascript
Node.js 如何利用异步提升任务处理速度
Jan 07 #Javascript
You might like
蝙蝠侠:侠影之谜
2020/03/04 欧美动漫
全国FM电台频率大全 - 15 山东省
2020/03/11 无线电
支付宝服务窗API接口开发php版本
2016/07/20 PHP
PHP正则验证字符串是否为数字的两种方法并附常用正则
2019/02/27 PHP
JS 统计时间
2021/03/09 Javascript
Gambit vs CL BO3 第三场 2.13
2021/03/10 DOTA
Prototype使用指南之array.js
2007/01/10 Javascript
jQuery之浮动窗口实现代码(两种方法)
2010/09/08 Javascript
用js调用迅雷下载代码的二种方法
2013/04/15 Javascript
js中数组排序sort方法的原理分析
2014/11/20 Javascript
node.js中的console.time方法使用说明
2014/12/09 Javascript
smartcrop.js智能图片裁剪库
2015/10/14 Javascript
理解javascript中DOM事件
2015/12/25 Javascript
一系列Bootstrap导航条使用方法分享
2016/04/29 Javascript
JS实现类似百叶窗下拉菜单效果
2016/12/30 Javascript
原生js封装自定义滚动条
2017/03/24 Javascript
vue弹窗组件使用方法
2018/04/28 Javascript
在ES5与ES6环境下处理函数默认参数的实现方法
2018/05/13 Javascript
解决angularjs前后端分离调用接口传递中文时中文乱码的问题
2018/08/13 Javascript
微信小程序网络请求实现过程解析
2019/11/06 Javascript
[32:39]完美世界DOTA2联赛循环赛 Forest vs Inki BO2第一场 11.04
2020/11/04 DOTA
深入浅析Python中join 和 split详解(推荐)
2016/06/30 Python
Python使用re模块实现信息筛选的方法
2018/04/29 Python
python 剪切移动文件的实现代码
2018/08/02 Python
python 循环读取txt文档 并转换成csv的方法
2018/10/26 Python
对Python中小整数对象池和大整数对象池的使用详解
2019/07/09 Python
python函数定义和调用过程详解
2020/02/09 Python
Python爬虫爬取百度搜索内容代码实例
2020/06/05 Python
基于css3 animate制作绚丽的动画效果
2015/11/24 HTML / CSS
Agoda中文官网:安可达(低价预订全球酒店)
2021/01/18 全球购物
UNIX特点都有哪些
2016/04/05 面试题
教师自我剖析材料范文
2014/09/30 职场文书
小学秋季运动会报道稿
2014/09/30 职场文书
2015年个人思想总结
2015/03/09 职场文书
vue引入Excel表格插件的方法
2021/04/28 Vue.js
vue如何实现关闭对话框后刷新列表
2022/04/08 Vue.js