Theia APIs——事件


上一篇:Theia APIs——Preferences

事件

  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)函數觸發事件

 

原文地址:https://theia-ide.org/docs/events


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM