当前位置: 首页 > news >正文

海口网站建设专家评价/深圳网络推广大师

海口网站建设专家评价,深圳网络推广大师,商城型网站建设代理加盟,网站建设报价 福州Node.js 事件 Node.js 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列。 Node.js 里面的许多对象都会分发事件:一个net.Server对象会在每次有新连接时分发一个事件, 一个fs.readStream对象会在文件被打开的时候发出一个事件。 所有这些产生事件…

Node.js 事件

Node.js 所有的异步 I/O 操作在完成时都会发送一个事件到事件队列。
Node.js 里面的许多对象都会分发事件:一个net.Server对象会在每次有新连接时分发一个事件, 一个fs.readStream对象会在文件被打开的时候发出一个事件。 所有这些产生事件的对象都是 events.EventEmitter 的实例。 你可以通过require(“events”);来访问该模块。

EventEmitter 类

events 模块只提供了一个对象: events.EventEmitter。EventEmitter 的核心就是事件触发与事件监听器功能的封装。可以通过require(“events”);来访问该模块。

例子

event.js:

//引入events并创建EventMitter对象
var EventEmitter = require('events').EventEmitter; 
//创建事件
var event = new EventEmitter(); 
//注册一个监听器,参数包括事件名和回调函数
event.on('some_event', function() { console.log('some_event 事件触发'); 
}); 
//在10秒后事件触发
setTimeout(function() { event.emit('some_event'); 
}, 10*1000); 

运行:
在这里插入图片描述
在这里插入图片描述
运行原理:
event 对象注册了事件 some_event 的一个监听器,然后通过 setTimeout 在 1o秒以后向 event 对象发送事件 some_event,此时会调用some_event 的监听器。
当事件触发时,注册到这个事件的事件监听器被依次调用,事件参数作为回调函数参数传递。

实例

eventb.js:

var events = require('events'); 
var emitter = new events.EventEmitter(); 
//someEvent事件监听器1
emitter.on('someEvent', function(arg1, arg2) { console.log('listener1', arg1, arg2); 
}); 
//someEvent事件监听器2
emitter.on('someEvent', function(arg1, arg2) { console.log('listener2', arg1, arg2); 
}); 
//触发事件
emitter.emit('someEvent', 'arg1 参数', 'arg2 参数'); 

运行:
在这里插入图片描述
emitter 为事件 someEvent 注册了两个事件监听器,然后触发了 someEvent 事件。
运行结果中可以看到两个事件监听器回调函数被先后调用。

EventEmitter api

方法

序号方法描述
1addListener(event, listener)为指定事件添加一个监听器到监听器数组的尾部。
2on(event, listener)为指定事件注册一个监听器,接受一个字符串 event 和一 个回调函数。
3once(event, listener)为指定事件注册一个单次监听器,即 监听器最多只会触发一次,触发后立刻解除该监听器。
4removeListener(event, listener)移除指定事件的某个监听器,监听器必须是该事件已经注册过的监听器。它接受两个参数,第一个是事件名称,第二个是回调函数名称。
5removeAllListeners([event])移除所有事件的所有监听器, 如果指定事件,则移除指定事件的所有监听器。
6setMaxListeners(n)默认情况下, EventEmitters 如果你添加的监听器超过 10 个就会输出警告信息。 setMaxListeners 函数用于提高监听器的默认限制的数量。
7listeners(event)返回指定事件的监听器数组。
8emit(event, [arg1], [arg2], […])按监听器的顺序执行执行每个监听器,如果事件有注册监听返回 true,否则返回 false。

类方法

序号方法描述
1listenerCount(emitter, event)返回指定事件的监听器数量。

事件

序号事件描述
1newListenerevent - 字符串,事件名称
listener - 处理事件函数
该事件在添加新监听器时被触发。
2removeListenerevent - 字符串,事件名称
listener - 处理事件函数
从指定监听器数组中删除一个监听器。需要注意的是,此操作将会改变处于被删监听器之后的那些监听器的索引。
实例

eventmain.js:

var events = require('events');
var eventEmitter = new events.EventEmitter();// 监听器 #1
var listener1 = function listener1() {console.log('监听器 listener1 执行。');
}// 监听器 #2
var listener2 = function listener2() {console.log('监听器 listener2 执行。');
}// 绑定 connection 事件,处理函数为 listener1 
eventEmitter.addListener('connection', listener1);// 绑定 connection 事件,处理函数为 listener2
eventEmitter.on('connection', listener2);var eventListeners = eventEmitter.listenerCount('connection');
console.log(eventListeners + " 个监听器监听连接事件。");// 处理 connection 事件 
eventEmitter.emit('connection');// 移除监绑定的 listener1 函数
eventEmitter.removeListener('connection', listener1);
console.log("listener1 不再受监听。");// 触发连接事件
eventEmitter.emit('connection');eventListeners = eventEmitter.listenerCount('connection');
console.log(eventListeners + " 个监听器监听连接事件。");console.log("程序执行完毕。");

运行:
在这里插入图片描述
参考:
【1】、https://www.runoob.com/nodejs/nodejs-event.html
【2】、https://www.w3cschool.cn/nodejs/nodejs-event.html

http://www.lbrq.cn/news/958663.html

相关文章:

  • 6617网址导航彩票网站大全/百度百度一下百度
  • 徐州 网站制作/哪些行业适合做网络推广
  • 新建网站怎么做优化/百度指数可以查询多长时间的
  • p2p的网站建设/百度推送
  • 网站被k怎么恢复/免费建网站哪家好
  • 做网站搭建的公司/天津搜索引擎seo
  • 网站流量30g/交友平台
  • 阿里云wordpress进不去/广州seo做得比较好的公司
  • 做网站谁家好/今日搜索排行榜
  • 精品网站建设费用 在线磐石网络/seo外链推广
  • 鹰潭北京网站建设/关键词推广排名
  • 北京网站设计制作教程/上海最专业的seo公司
  • 做t-shirt素材网站/网络营销课程设计
  • 公司做网站需要哪些费用/上海网站建设方案
  • 和狗做网站/关键词优化推广公司
  • 在一起做网店的网站的怎么购买/域名停靠网页推广大全2021
  • wordpress 添加首页/seo排名优化怎么样
  • 给人做时时彩网站建设/沈阳seo
  • 做风水网站赚钱吗/网站设计说明
  • 关于进一步加强门户网站建设/网络营销的三大基础
  • 腾讯客服平台/搜索引擎优化中的步骤包括
  • 网站建设为什么要推广/太原seo排名优化公司
  • 聊城网站建设方案/打开百度官网
  • 小精灵网站在线做语文/杭州网站
  • 个人网站备案怎么写/seo项目分析
  • 名词解释seo/seo推广培训中心
  • 有哪些做红色旅游景点的网站/网站seo关键词排名查询
  • wordpress网站制作教程/免费网站在线客服系统源码
  • 网站建设飠金手指科杰十五/正规seo需要多少钱
  • 亚马逊网站特点和经营范围/谷歌搜索引擎免费入口
  • 使用UV管理FastAPI项目
  • LVS的简介以及架构
  • 【Qt开发】Qt的背景介绍(三)-> 认识Qt Creator
  • 目标框的位置以及大小的分布
  • wedo牛-----第47节(免费分享图纸)
  • 服务端高并发方案设计