node的events模块

events可以说是node实现异步的基石,也是其他几个常用核心模块api的异步方法的原型。

1 var eventEmitter=require(‘events‘).EventEmitter;
2 //var eventEmitter=require(‘events‘);  这样写也可以
3 var myEvent=new eventEmitter();
4 myEvent.on(‘shout‘,function(){console.log(‘Oh‘)})
5 myEvent.emit(‘shout‘);

引入events模块后,用它生成一个事件实例,就可以使用该实例的on方法监听(绑定)事件,emit方法触发事件,emit方法返回一个布尔值表示该事件是否已被监听。

EventEmitter.addListener()和on()方法类似,用以添加事件;

EventEmitter.removeListener(),用以移除事件;

1.可以给一个事件绑定多个回调,触发时回调按注册顺序依次执行;但不建议绑定太多(实话,现实情况也完全很少遇到一个时间绑定超过3个callback),怕造成内存泄漏。绑定的回调超过十个node会警告,可以通过.setMaxListener(int)改动允许的最大绑定数。

2.在事件的callback中,this指向myEvent本身;如果callback用的是箭头函数,则不指向myEvent,可能是个空对象{}。

3.在callback中,可以使用setImmediate() 或 process.nextTick() 方法延迟代码的执行以达到异步的效果...嗯。。就像在客户端用定时器一样;不过这种做法在具体生产中。。看情况吧。。

1 const myEmitter = new MyEmitter();
2 myEmitter.on(‘event‘, (a, b) => {
3   setImmediate(() => {
4     console.log(‘this happens asynchronously‘);
5   });
6 });
7 myEmitter.emit(‘event‘, ‘a‘, ‘b‘);

4.eventEmitter.once():用法和.on()一样,不过.once绑定的事件只触发一次,再次触发会被忽略。(node绝对是参考了jQ啊有木有~~)

5.‘error’事件,文档提到,如果一个EventEmitter运行过程中出现了错误,会抛出一个error事件;但如果EventEmitter没有监听error事件,而error被抛出,则node会打印堆栈的踪迹并退出进程。所以我们使用EventEmitter实例的时候往往要绑定一个error事件,哪怕只是log一下。

6.newListener事件会被触发当我们给EventEmitter实例绑定事件的时候;removeListener事件会被触发当我们移除事件的时候。

 1 const myEmitter = new MyEmitter();
 2 // Only do this once so we don‘t loop forever
 3 myEmitter.once(‘newListener‘, (event, listener) => {
 4   if (event === ‘event‘) {
 5     // Insert a new listener in front
 6     myEmitter.on(‘event‘, () => {
 7       console.log(‘B‘);
 8     });
 9   }
10 });
11 myEmitter.on(‘event‘, () => {
12   console.log(‘A‘);
13 });
14 myEmitter.emit(‘event‘);
15 // Prints:
16 //   B
17 //   A

这里要注意,在触发newListener是事件的时候,newListener的回调会在绑定新事件的时候执行,因此log(B)在‘event‘被触发的时候就注册了。

另外,代码第三行的listener参数,指向的是代码第12行的代码,即EventEmitter实例绑定‘event‘事件的回调。

7.EventEmitter.listenerCount(emitter, eventName):静态的方法,返回一个EventEmitter实例监听的某个事件到底绑定了多少个回调,在文档中,listener指的就是某个event的callback。

1 const myEmitter = new MyEmitter();
2 myEmitter.on(‘event‘, () => {});
3 myEmitter.on(‘event‘, () => {});
4 console.log(EventEmitter.listenerCount(myEmitter, ‘event‘));
5 // Prints: 2

8.EventEmitter.defaultMaxListeners:默认的单个event最大listener数(对所有event都这样),为10,但实际上可以绑定第11、12个以上的listener,只是超过10个node会给出warning;

emitter.setMaxListeners(n) :改变单个event的限制。

.getMaxListeners():获取单个event的最大listener数,如果该event调用过.setMaxListeners(n)方法,则获取的是set后的值。

1 emitter.setMaxListeners(emitter.getMaxListeners() + 1);
2 emitter.once(‘event‘, () => {
3   // do stuff
4   emitter.setMaxListeners(Math.max(emitter.getMaxListeners() - 1, 0));
5 });

9.emitter.eventNames():返回一个数组,其元素是该EventEmitter实例绑定的事件名。

10.emitter.listenerCount(eventName):返回实例绑定的某个事件的lietener数。

11.emitter.listeners(eventName):返回一个数组,该数组成员是EventEmitter实例绑定的事件的lietener的副本。(个人觉得鸡肋)

1 server.on(‘connection‘, (stream) => {
2   console.log(‘someone connected!‘);
3 });
4 console.log(util.inspect(server.listeners(‘connection‘)));
5 // Prints: [ [Function] ]

12.emitter.prependListener(eventName, listener):将listener插入到某个event所注册的listeners队列的最前面,类似数组的unshift方法,由于event触发的时候listeners是按注册顺序逐个执行的,所以使用该方法的listener会第一个执行。

13.emitter.prependOnceListener(eventName, listener):跟上面的prependListener()方法一样,只是prependOnceListener插入的listener只触发一次。

14.emitter.removeAllListeners([eventName]):移除EventEmitter实例绑定的eventName的所有listeners。

15.emitter.removeListener(eventName, listener):移除某个事件。这个callback必须是个句柄,和DOM二级事件的removeEventListener一样。另外,由于同一个listener可以反复添加给某个event,在触发时也会反复执行,此时想彻底清除该事件就得多次使用removeListener。

好啦,events模块大体就这些方法。我是文档的搬运工。。。。。

时间: 2024-10-06 16:35:59

node的events模块的相关文章

node模块之events模块

events 模块只提供了一个对象: events.EventEmitter. [EventEmitter 的核心就是事件触发与事件监听器功能的封装.] EventEmitter 的每个事件由一个事件名和若干个参 数组成,事件名是一个字符串,通常表达一定的语义.对于每个事件,EventEmitter 支持 若干个事件监听器.当事件触发时,注册到这个事件的事件监听器被依次调用,事件参数作 为回调函数参数传递. 例子: var events = require('events'); var emit

node的事件模块应用(译)

第一次接触Node.js时,就觉得他只不过是用javascript实现的服务端.但实际上他提供了许多浏览器端不具备的方法,比如EventEmitter类.我们在本文中来学习如何使用EventEmitter. EventEmitter是什么? 简单来说,使用EventEmitter,你可以监听一个事件,并且可以执行一个你绑定的回调函数.就像前端的javascript一样,你可以通过addEventListener来绑定用户的鼠标键盘交互事件,EventEmitter是基于发布订阅模式,因此我们可以

Node.js(二)——模块与包管理工具

http,process等等这些都是模块 一.Node.js的模块与Commonjs规范 1.js的天生缺陷--缺少模块化管理机制 ·表现--JS中容易出现变量被覆盖,方法被替代的情况(既被污染).特别是存在依赖关系时,容易出现错误.这是因为JS缺少模块管理机制,来隔离实现各种不同功能的JS判断,避免它们相互污染. ·解决--经常采用命名空间的方式,把变量和函数限制在某个特定的作用域内,人肉约定一套命名规范来限制代码,保证代码安全运行.jQuery中有许多变量和方法,但是无法直接访问,必须通过j

Node.js文件模块fs监视文件变化

Node.js文件模块fs监视文件变化 Node中文件模块fs监视文件的函数源码如下: fs.watch = function(filename) { nullCheck(filename); var watcher; var options; var listener; if (util.isObject(arguments[1])) { options = arguments[1]; listener = arguments[2]; } else { options = {}; listen

Node.js 的模块系统

Node.js的模块系统是借鉴 CommonJS 的 Modules 规范实现的,因此,下面我们需要先了解 CommonJS 的 Modules 规范,希望对大家学习Node.js有所帮助. CommonJS 的 Modules 规范 CommonJS 对模块的定义非常简单,主要分为 模块引用.模块定义和模块标识三个部分. 1. 模块引用 - require() 方法 2. 模块定义 - module.exports 对象 3. 模块标识 - 传递给 require() 方法的参数 通过 Com

node.js基础模块http、网页分析工具cherrio实现爬虫

node.js基础模块http.网页分析工具cherrio实现爬虫 一.前言      说是爬虫初探,其实并没有用到爬虫相关第三方类库,主要用了node.js基础模块http.网页分析工具cherrio. 使用http直接获取url路径对应网页资源,然后使用cherrio分析. 这里我主要学习过的案例自己敲了一遍,加深理解.在coding的过程中,我第一次把jq获取后的对象直接用forEach遍历,直接报错,是因为jq没有对应的这个方法,只有js数组可以调用. 二.知识点    ①:supera

(译)Node.js的模块-exports和module.exports

原文标题:Node.js Module – exports vs module.exports原文链接:http://www.hacksparrow.com/node-js-exports-vs-module-exports.html exports 和 module.exports 有什么区别? 你一定很熟悉 Node.js 模块中的用来在你的模块中创建函数的 exports 对象,就像下面这样. 创建一个叫做rocker.js的文件: exports.name = function() {

Backbone事件管理——Backbone.Events模块API结构

模块Backbone.Events的事件管理是通过Backbone提供的Events API来实现的,该API在1.0版本之前仅仅提供了几个基本的方法,如on.off.trigger.once分别执行对事件的绑定.解除绑定.执行事件.执行一次事件的操作.从1.0版本以后,又添加了几个实用方法,如listenTo.listenToOnce.stopListening,分别执行添加一个事件的侦察对象.添加一个仅执行一次的事件侦察对象和移除已添加的事件侦察对象,其完整的结构如图3-1所示. Backb

node.js笔记——模块的开发

模块是什么? 简单来说模块是用来将实现某个功能的代码进行封装以便在其他项目中通过简单引入的方式实现模块中封装的功能的一个东西!!(我更想管他叫小程序). 模块的引入 模块的引入使用reqiure()函数来实现例如引入http模块 var h = require("http"); 这里需要注意的是require()加载函数可以加载指定的js文件,当引入的不是某个js文件而是一段没有扩展名的字符时,默认node.js会加载当前根目录下的node_modules文件夹下面的文件夹里的文件 并