2

在我的主机应用程序中,我有一个按钮,单击该按钮时,会将数据与数据一起发送到我的角度应用程序。像这样:

<button (click)="onClick()">Send Some Data</button>

零件:

onClick() {  
ipcRenderer.send("data-bridge",{name: 'John Smith', address: 'Main Street', date: new Date() );
}

在我的角度应用程序中,我收到如下数据:

import { ElectronService } from 'ngx-electron';

export class AppComponent {
  constructor( private electronService: ElectronService) {}

   ngOnInit() {
    if (this.electronService.ipcRenderer) {

      this.electronService.ipcRenderer.on('data-bridge', (event, data) => {
            console.log('got something', data)
        })
    }
  }
}

我注意到的行为是,在我单击按钮 x 次时,我将看到警报 x 次:

  • 1 次单击 --> 1 个警报
  • 2 单击 --> 2 个警报
  • 3单击-> 3个警报..等等

所以这显然向我表明存在内存泄漏。解决方案很简单,在接收到事件后移除事件监听器。

我试过做类似的事情:

this.electronService.ipcRenderer.on('data-bridge', (event, data) => {
        alert('got something');
        this.electronService.ipcRenderer.removeAllListeners()
}

但是多个警报仍然发生在单击一次。

我不能使用 ipcRenderer.once 方法,因为我需要监听器保持打开状态,只是没有多个相同的监听器。如何删除 ipcRenderer.on('data-bridge', ...) 事件侦听器,以便每次单击按钮时,我只有一个事件侦听器?

4

1 回答 1

4

ipcRenderer是一个EventEmitter类,所以你有removeListener(eventName, listener)(或off)方法。

这应该工作

// on construct
this.onData = (event, data) => {
  console.log('got something', data)
})
// on init
ipcRenderer.on('data-bridge', this.onData)
// on deconstruct
ipcRenderer.removeListener('data-bridge', this.onData)
于 2019-08-09T05:07:18.563 回答