看用TypeScript怎樣實現(xiàn)常見的設(shè)計模式,順便復習一下。
學模式最重要的不是記UML,而是知道什么模式可以解決什么樣的問題,在做項目時碰到問題可以想到用哪個模式可以解決,UML忘了可以查,思想記住就好。
這里盡量用原創(chuàng)的,實際中能碰到的例子來說明模式的特點和用處。

解釋器模式 Interpreter

特點:使用給定語法來解釋一段內(nèi)容。

用處:管理類系統(tǒng)經(jīng)常會定義一些搜索語句格式來使用戶方便搜索庫里的內(nèi)容,這時就可以考慮用解釋器來翻譯執(zhí)行這些語句。

注意:適合相對簡單的語法。

解釋器模式通過把一段表達式拆開成很多個,分為不同的解析類,一個一個的去解析并執(zhí)行,這過程中經(jīng)常會用Context來保存解析過程的信息。
這種解釋器的優(yōu)點在于各種表達式的解析相對獨立,要加入新的規(guī)則也不會影響現(xiàn)有的解析。缺點也很明顯,一個表達式一個類,復雜語法或復合語法的話表達式數(shù)量就非常多,并且表達式之間也很難真正獨立。

下面用TypeScript寫一個簡單正則表達式的解釋器:
要解釋的表達式有:{}, [], \d, ^, $這幾種。

先建立一個Expression接口,所有解釋器都實現(xiàn)這個接口:

interface Expression{
    interpret(context: Context);
}

可以看到接口里用到了一個Context,這個用來保存解析時的一些數(shù)據(jù)和進度,包含:
pattern: 整個表達式
currentPatternIndex: 當前正在驗證的表達式的位置
lastExpression: 上一個表達式,用于{}解析
text: 需要驗證的文本
currentTextIndex: 當前驗證到text里的哪個字符的位置
isMatch: 是否匹配成功

class Context{    constructor(public pattern: string, public text: string){

    }

    currentTextIndex: number = 0;    get currentText(): string{        return this.text[this.currentTextIndex];
    }

    currentPatternIndex: number = 0;
    lastExpression: string;    get&nbs