首页 / JAVASCRIPT / node事件机制解说
node事件机制解说
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了node事件机制解说,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4177字,纯文字阅读大概需要6分钟。
内容图文
![node事件机制解说](/upload/InfoBanner/zyjiaocheng/296/1d114031e7064ed8879cb8b39f10ce48.jpg)
Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient.
在nodejs的官方文档中,明确写出了node的一个特性是event-driven(事件驱动),可见其非常重要。查看源码,我们可知其事件机制为用js写的EventEmitter类,写得非常优雅且应用了发布/订阅模式。
通过实现一个简易的、具有发布/订阅模式的事件机制,以此来理清EventEmitter类的实现思路
Publish/Subscribe(发布/订阅模式)
类比
要讲的是一个模式,模式这个词,听起来就很抽象。我们先举个栗子。假设有一家报纸机构,提供晨报、午报、晚报。如果你想要看某种报纸,你需要向报纸机构订阅,等对应的报纸发布出来后,报纸机构就会通知你来拿报纸。
在这个过程中,报纸机构实现了两个功能,一是接受客户的订阅;二是发布不同类型的报纸。发布报纸的时候,订阅该类型报纸的客户就能接收到通知。
这个报纸机构也就是我们要实现的事件机制。
目的
从上面的例子可以看出:1.发布报纸;2.将报纸给到客户;这个连续的过程由于报纸机构的存在,变成了可以先订阅,再发布,等到发布就自动送到客户手中,实现了动作时间上的分离。这也是发布/订阅系统的优势。
实现思路
我们有3种报纸,对应3个事件,每个事件发生时要通知客户。对应的数据格式可以如下:
由于每种报纸都可能有不止一个人订阅,那么格式可优化成这样:
当用户订阅的时候,我们就将其事件添加对应的数组中;当事件发布的时候,就执行相应事件。说白了就是先存储后使用。
具体代码如下:
1.on表示订阅,将事件添加到对应数组中
2.emit表示发布,将对应数组中的数据取出来执行
3.off表示删除无用的事件
node的EventEmitter
node的EventEmitter基本逻辑和上面提供的例子基本一样,只是更加复杂些。
1.订阅事件on
2.发布事件
讲到这里,相信大家已经明白EventEmitter的实现思路。
相关推荐:
PHP事件机制的实现
jq与js中的事件机制与阻止
JavaScript的事件机制
以上就是node事件机制解说的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的node事件机制解说全部内容,希望文章能够帮你解决node事件机制解说所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。