事件
Theia中的事件或許會讓你感到困惑,希望本節能闡述清楚。
來看下面的代碼:
(來自logger-watcher.ts)
@injectable() export class LoggerWatcher { getLoggerClient(): ILoggerClient { const emitter = this.onLogLevelChangedEmitter return { onLogLevelChanged(event: ILogLevelChangedEvent) { emitter.fire(event) } } } private onLogLevelChangedEmitter = new Emitter<ILogLevelChangedEvent>(); get onLogLevelChanged(): Event<ILogLevelChangedEvent> { return this.onLogLevelChangedEmitter.event; } }
先來看看這一行:
private onLogLevelChangedEmitter = new Emitter<ILogLevelChangedEvent>();
首先,什么是
Emitter?
Emitter是事件處理程序的容器,可以在上面注冊事件處理程序並使用類型為X的事件觸發它,在上面的例子中,X的類型為ILogLevelChangedEvent。
所以這里我們創建了一個
Emitter,它將包含所有類型為ILogLevelChangedEvent的事件。
接下來,我們希望能夠在這個
Emitter上注冊一個事件處理程序,可以像這樣:
get onLogLevelChanged(): Event<ILogLevelChangedEvent> { return this.onLogLevelChangedEmitter.event; }
它實際返回的是一個函數,用來注冊事件處理程序,你只需要將事件處理程序的函數傳遞給它,它將注冊該事件,然后當事件觸發的時候該處理程序會被調用。
你可以這樣調用:
(來自logger.ts)
/* Update the root logger log level if it changes in the backend. */ loggerWatcher.onLogLevelChanged(event => { this.id.then(id => { if (id === this.rootLoggerId) { this._logLevel = Promise.resolve(event.newLogLevel); } }); });
這將在emitter上注冊一個匿名函數,並將其作為參數進行傳遞。
接下來,我們需要觸發一個事件來執行該事件處理程序。
onLogLevelChanged(event: ILogLevelChangedEvent) {
emitter.fire(event)
}
當調用該函數時,emitter觸發並調用所有的事件處理程序。
所以,如果你想在Theia中觸發事件,需要:
-
創建一個emitter
-
使用emitter.event函數注冊事件
-
使用emitter.fire(event)函數觸發事件