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 window.opener的用法分析
Apr 07 Javascript
JS实现点击链接取消跳转效果的方法
Jan 24 Javascript
javascript实现页面刷新时自动清空表单并选中的方法
Jul 18 Javascript
全面理解闭包机制
Jul 11 Javascript
jQuery实现可移动选项的左右下拉列表示例
Dec 26 Javascript
jQuery+Ajax实现用户名重名实时检测
Jun 01 jQuery
package.json文件配置详解
Jun 15 Javascript
JavaScript调试之console.log调试的一个小技巧分享
Aug 07 Javascript
用 Vue.js 递归组件实现可折叠的树形菜单(demo)
Dec 25 Javascript
详解关于element el-button使用$attrs的一个注意要点
Nov 09 Javascript
Vue源码学习之关于对Array的数据侦听实现
Apr 23 Javascript
JavaScript实现串行请求的示例代码
Sep 14 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类
2006/11/25 PHP
使用php验证复选框有效性的示例
2013/11/13 PHP
PHP结合Redis+MySQL实现冷热数据交换应用案例详解
2019/07/09 PHP
被jQuery折腾得半死,揭秘为何jQuery为何在IE/Firefox下均无法使用
2010/01/22 Javascript
jQuery EasyUI API 中文文档 - Menu菜单
2011/10/03 Javascript
js的匿名函数使用介绍
2013/12/11 Javascript
Yii2使用Bootbox插件实现自定义弹窗
2015/04/02 Javascript
情人节单身的我是如何在敲完代码之后收到12束玫瑰的(javascript)
2015/08/21 Javascript
js实现prototype扩展的方法(字符串,日期,数组扩展)
2016/01/14 Javascript
微信小程序 页面传参实例详解
2016/11/16 Javascript
bootstrap css样式之表单
2017/01/19 Javascript
VUE axios上传图片到七牛的实例代码
2017/07/28 Javascript
前端图片懒加载(lazyload)的实现方法(提高用户体验)
2017/08/21 Javascript
Vue.js devtool插件安装后无法使用的解决办法
2017/11/27 Javascript
vue之父子组件间通信实例讲解(props、$ref、$emit)
2018/05/22 Javascript
React 使用browserHistory项目访问404问题解决
2018/06/01 Javascript
小程序自定义组件实现城市选择功能
2018/07/18 Javascript
ssm+vue前后端分离框架整合实现(附源码)
2020/07/08 Javascript
简单理解Python中基于生成器的状态机
2015/04/13 Python
JSON Web Tokens的实现原理
2017/04/02 Python
Python列表list操作符实例分析【标准类型操作符、切片、连接字符、列表解析、重复操作等】
2017/07/24 Python
详解Python最长公共子串和最长公共子序列的实现
2018/07/07 Python
Python中logging实例讲解
2019/01/17 Python
Python中常用的8种字符串操作方法
2019/05/06 Python
python使用mitmproxy抓取浏览器请求的方法
2019/07/02 Python
python numpy生成等差数列、等比数列的实例
2020/02/25 Python
python实现3D地图可视化
2020/03/25 Python
如何实现更换Jupyter Notebook内核Python版本
2020/05/18 Python
英国知名小木屋定制网站:Tiger Sheds
2020/03/06 全球购物
医学生求职自荐信
2013/10/25 职场文书
大学生冰淇淋店商业计划书
2014/01/14 职场文书
会计电算化学生个人的自我评价
2014/02/08 职场文书
领导班子个人查摆问题对照检查材料
2014/10/02 职场文书
大一新生检讨书
2014/10/29 职场文书
2014年导购员工作总结
2014/11/18 职场文书
介绍信格式样本
2015/05/05 职场文书