前言
本文主要给大家介绍了关于node.js事件模块Events使用的一些示例,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
环境:Node v8.2.1; Npm v5.3.0; OS Windows10
1、 Node事件介绍
Node大多数核心 API 都采用惯用的异步事件驱动架构,其中某些类型的对象(触发器)会周期性地触发命名事件来调用函数对象(监听器)。
所有能触发事件的对象都是 EventEmitter 类的实例。 这些对象开放了一个 eventEmitter.on() 函数,允许将一个或多个函数绑定到会被对象触发的命名事件上。 事件名称通常是驼峰式的字符串,但也可以使用任何有效的 JavaScript 属性名。
当 EventEmitter 对象触发一个事件时,所有绑定在该事件上的函数都被同步地调用。 监听器的返回值会被丢弃。
2、events 模块API介绍
3、 一些例子
下面是一些简单的例子,对应上面的API的一个代码实现
3.1 绑定和触发事件
const EventEmitter = require('events'); //自定义一个对象继承于EventEmitter class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); myEmitter.on('event', () => { console.log('触发了一个事件!'); }); myEmitter.emit('event');
3.2 为事件传递参数
const EventEmitter = require('events'); class MyEmitter extends EventEmitter {} const myEmitter = new MyEmitter(); myEmitter.on('event', (a,b) => { console.log(a,b); //1,2 }); myEmitter.emit('event','a','b');
3.3 this 的问题
当一个普通的监听器函数被 EventEmitter 调用时,标准的 this 关键词会被设置指向监听器所附加的 EventEmitter。
const EventEmitter = require('events'); class MyEmitter extends EventEmitter {} const myEmitter = new MyEmitter(); myEmitter.on('event', function() { console.log(this); /* a b MyEmitter { domain: null, _events: { event: [Function] }, _eventsCount: 1, _maxListeners: undefined } */ }); myEmitter.emit('event');
也可以使用 ES6 的箭头函数作为监听器。但是这样 this 关键词就不再指向 EventEmitter 实例:
const EventEmitter = require('events'); class MyEmitter extends EventEmitter {} const myEmitter = new MyEmitter(); myEmitter.on('event', () => { console.log(this); //{} }); myEmitter.emit('event');
3.4 异步执行
EventListener 会按照监听器注册的顺序同步地调用所有监听器,监听器函数可以使用 setImmediate()
或 process.nextTick()
方法切换到异步操作模式:
const EventEmitter = require('events'); class MyEmitter extends EventEmitter {} const myEmitter = new MyEmitter(); myEmitter.on('event', (a,b) => { setImmediate(()=>{ //异步触发 console.log(a,b); }) console.log("c"); }); myEmitter.emit('event','a','b'); //c //a b
3.5 无限次触发和一次触发
事件默认是可以无限次数的触发的,只要触发一次,对应的监听函数就执行一次;有时候我们希望只执行一次监听函数,可以使用【once】对事件进行绑定
多次触发:
const EventEmitter = require('events') class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); let m = 0; myEmitter.on('event', () => { console.log(++m); }); myEmitter.emit('event'); //1 myEmitter.emit('event'); //2 myEmitter.emit('event'); //3
一次触发:
const EventEmitter = require('events') class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); let m = 0; myEmitter.once('event', () => { console.log(++m); }); myEmitter.emit('event'); //1 myEmitter.emit('event'); //忽略 myEmitter.emit('event'); //忽略
3.6 错误事件
当 EventEmitter 实例中发生错误时,会触发一个 ‘error' 事件,如果 EventEmitter 没有为 ‘error' 事件注册至少一个监听器,则当 ‘error' 事件触发时,会抛出错误、打印堆栈跟踪、且退出 Node.js 进程。
const EventEmitter = require('events'); class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); myEmitter.emit("error", new Error('whoops!')); // 抛出错误,并使 Node.js 崩溃
为了防止 Node.js 进程崩溃,可以在 process 对象的 uncaughtException 事件上注册监听器
const EventEmitter = require('events') class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); //在进程上面注册错误监听,使进程不崩溃 process.on("uncaughtException",()=>{ console.error('有错误'); }); myEmitter.emit("error",new Error("whoops"))
上面这样的方式并不是最佳实践,最好是为【error】注册监听函数
3.7 获取和修改最大事件监听数量
Node默认一个事件的监听数量为10个,超过十个将会发出警告
const EventEmitter = require('events') class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); console.log(EventEmitter.defaultMaxListeners); //10 for (let i = 0; i < 11; i++) { myEmitter.on("event", () => { console.log(i); }); } myEmitter.emit("event") //MaxListenersExceededWarning: Possible EventEmitter memory leak detected. 11 event listeners added. Use emitter.setMaxListeners() to increase limit
改变指定的 EventEmitter 实例的监听器限制
const EventEmitter = require('events') class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter(); myEmitter.setMaxListeners(13); for (let i = 0; i < 11; i++) { myEmitter.on("event", () => { console.log(i); }); } myEmitter.emit("event")
3.8 newListener事件
EventEmitter 实例会在一个监听器被添加到其内部监听器数组【之前】触发自身的 ‘newListener' 事件
const EventEmitter = require('events') class MyEmitter extends EventEmitter { } const myEmitter = new MyEmitter() myEmitter.once("newListener", (event, listener) => { if(event === "event"){ myEmitter.on("event",()=>{ console.log("B"); }) } }); myEmitter.on("event",()=>{ console.log("A"); }); myEmitter.emit("event") /* B A */
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 林隆璇.1989-愤怒的情歌【巨石】【WAV+CUE】
- 勤琴《海上花》[DTS-WAV分轨]
- 群星《歌声有故事》[DTS-WAV分轨]
- [发烧人声]群星《邂逅》DTS-WAV
- 艻打绿《夏/狂热(苏打绿版)》[320K/MP3][106.42MB]
- 艻打绿《夏/狂热(苏打绿版)》[FLAC分轨][574.2MB]
- 黄雨勳《魔法列车首部曲》[320K/MP3][33.1MB]
- 李蕙敏.2014-记得·销魂新歌+精丫乐意唱片】【WAV+CUE】
- 谢金燕.1995-含泪跳恰蔷冠登】【WAV+CUE】
- 于文文.2024-天蝎座【华纳】【FLAC分轨】
- 黄雨勳《魔法列车首部曲》[FLAC/分轨][173.61MB]
- 群星《歌手2024 第13期》[320K/MP3][50.09MB]
- 群星《歌手2024 第13期》[FLAC/分轨][325.93MB]
- 阿木乃《爱情买卖》DTS-ES【NRG镜像】
- 江蕾《爱是这样甜》DTS-WAV