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

解釋器模式 Interpreter

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

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

注意:適合相對(duì)簡(jiǎn)單的語法。

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

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

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

interface Expression{
    interpret(context: Context);
}

可以看到接口里用到了一個(gè)Context,這個(gè)用來保存解析時(shí)的一些數(shù)據(jù)和進(jìn)度,包含:
pattern: 整個(gè)表達(dá)式
currentPatternIndex: 當(dāng)前正在驗(yàn)證的表達(dá)式的位置
lastExpression: 上一個(gè)表達(dá)式,用于{}解析
text: 需要驗(yàn)證的文本
currentTextIndex: 當(dāng)前驗(yàn)證到text里的哪個(gè)字符的位置
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
        
		

網(wǎng)友評(píng)論