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 相关文章推荐
(推荐一个超好的JS函数库)S.Sams Lifexperience ScriptClassLib
Apr 29 Javascript
js 手机号码合法性验证代码集合
Sep 29 Javascript
jquery等宽输出文字插件使用介绍
Sep 18 Javascript
js+cookies实现悬浮购物车的方法
May 25 Javascript
jQuery判断元素是否显示 是否隐藏的简单实现代码
May 19 Javascript
jQuery EasyUI API 中文帮助文档和扩展实例
Aug 01 Javascript
javascript 中null和undefined区分和比较
Apr 19 Javascript
Electron-vue脚手架改造vue项目的方法
Oct 22 Javascript
vue使用video.js进行视频播放功能
Jul 18 Javascript
JavaScript this在函数中的指向及实例详解
Oct 14 Javascript
js实现漂亮的星空背景
Nov 01 Javascript
分享几个JavaScript运算符的使用技巧
Apr 24 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
PHP的一个完整SMTP类(解决邮件服务器需要验证时的问题)
2006/10/09 PHP
php 接口类与抽象类的实际作用
2009/11/26 PHP
PHP中array_keys和array_unique函数源码的分析
2016/02/26 PHP
一个简单的php MVC留言本实例代码(必看篇)
2016/09/22 PHP
PHP使用imagick扩展实现合并图像的方法
2017/04/25 PHP
Laravel框架源码解析之入口文件原理分析
2020/05/14 PHP
JQuery 学习技巧总结
2010/05/21 Javascript
jquery实现多级下拉菜单的实例代码
2013/10/02 Javascript
使用jquery prev()方法找到同级的前一个元素
2014/07/11 Javascript
jQuery调用WebMethod(PageMethod) NET2.0的方法
2016/04/15 Javascript
JsChart组件使用详解
2018/03/04 Javascript
通过jquery toggleClass()属性制作文章段落更改背景颜色
2018/05/21 jQuery
学习python处理python编码问题
2011/03/13 Python
python获取糗百图片代码实例
2013/12/18 Python
Python实现多行注释的另类方法
2014/08/22 Python
python中dir函数用法分析
2015/04/17 Python
用Python进行行为驱动开发的入门教程
2015/04/23 Python
Python基于pygame实现的font游戏字体(附源码)
2015/11/11 Python
对Python中9种生成新对象的方法总结
2018/05/23 Python
Python学习笔记之lambda表达式用法详解
2019/08/08 Python
python3实现高效的端口扫描
2019/08/31 Python
pycharm中导入模块错误时提示Try to run this command from the system terminal
2020/03/26 Python
Python logging模块写入中文出现乱码
2020/05/21 Python
python中rc1什么意思
2020/06/19 Python
python进行二次方程式计算的实例讲解
2020/12/06 Python
美国庭院家具购物网站:AlphaMarts
2019/04/10 全球购物
2014厂务公开实施方案
2014/02/17 职场文书
党的群众路线教育实践活动心得体会900字
2014/03/07 职场文书
初三学习决心书
2014/03/11 职场文书
经理秘书求职自荐信范文
2014/03/23 职场文书
民族团结好少年事迹材料
2014/08/19 职场文书
期中考试复习计划
2015/01/19 职场文书
中学后勤工作总结2015
2015/07/22 职场文书
学习焦裕禄先进事迹心得体会
2016/01/23 职场文书
《槐乡的孩子》教学反思
2016/02/20 职场文书
2019年描写人生经典诗句大全
2019/07/08 职场文书