• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Angular5集成eventbus的示例代码

angularjs 搞代码 4年前 (2021-12-31) 42次浏览 已收录 0个评论

这篇文章主要介绍了Angular5集成eventbus的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

1.package.json中

 "dependencies": { ... "vertx3-eventbus-client": "3.5.2", }, 

然后  npm install,或者:

 npm install [email protected]

2.angular-cli.json中

 "scripts": [ ... "../node_modules/vertx3-eventbus-client/vertx-eventbus.js" ], 

3.创建一个eventbus.service.ts用来通信

导入eventbus:

 import { EventBus } from 'vertx3-eventbus-client';

声明eventbus:

 declare var EventBus: any;

4.创建eventbus实例,监听接口以及发送消息

 //创建实例 var eb = new EventBus('http://localhost:8080/eventbus'); eb.onopen = function() { //注册监听器用来接受消息 eb.registerHandler('some-address', function(error, message) { console.log('received a message: ' + JSON.stringify(message)); }); //发送消息 eb.send('some-address', {name: 'tim', age: 587<div style="color:transparent">来源gaodai.ma#com搞##代!^码网</div>}); } 

更多信息请参考这里 https://vertx.io/docs/vertx-web/java/

注:

对于需要发送消息来接受的消息,需要先监听,然后再发送消息。
对于一直推送的消息,不需要发送。

代码实例如下:

 RegisterHandler(key, id, callback) { const address = '***.' + key + '.' + id; if (typeof (this.eventBus[key]) === 'undefined' || !this.eventBus[key]) { this.eventBus[key] = new EventBus(environment.eventbusUrl); } if (this.eventBus[key].state === EventBus.OPEN) { this.eventBus[key].registerHandler(address, callback); } else { const $this = this; this.eventBus[key].onopen = function () { $this.eventBus[key].registerHandler(address, callback) } } } Send(key, id) { var data = ''; const address = ***.' + key + '.' + id; if (typeof (this.eventBus[key]) === 'undefined' || !this.eventBus[key]) { this.eventBus[key] = new EventBus(environment.eventbusUrl); } if (this.eventBus[key].state === EventBus.OPEN) { this.eventBus[key].send(address, data) } else { const $this = this; this.eventBus[key].onopen = function () { $this.eventBus[key].send(address, data) } } } closeEventBus(key) { if (typeof (this.eventBus[key]) !== 'undefined' && this.eventBus[key] && this.eventBus[key].state === EventBus.OPEN) { this.eventBus[key].close(); } this.eventBus[key] = null; } 

在组件ngOnDestroy中调用closeEventBus关闭eventbus。

以上就是Angular5集成eventbus的示例代码的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Angular5集成eventbus的示例代码

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址