歡迎來到“類型腳本中的設計模式”系列,它介紹了使用類型腳本進行 Web 開發(fā)中的一些有用的設計模式。
設計模式對于Web開發(fā)人員來說非常重要,我們可以通過掌握它們來編寫更好的代碼。在本文中,我將使用類型腳本來介紹模板方法模式。
CSV(逗號分隔值)是一種通用的、相對簡單的文件格式。CSV 文件以純文本形式存儲表格數(shù)據(jù)(數(shù)字和文本)。當您需要處理CSV數(shù)據(jù)時,對應的處理流程如下圖所示:
在了解了上面的處理流程之后,讓我們使用 Node.js來實現(xiàn)解析 csv 文件的功能。
用戶.csv
parse-csv.ts
在上面的代碼中,我們導入 d3-dsv 模塊來實現(xiàn) csv 的解析功能。之后,我們使用 esno 來執(zhí)行解析 cvs.ts 文件:
當上述代碼成功運行時,終端將輸出以下結果:
Markdown是一種輕量級標記語言,允許人們以易于閱讀和寫入的純文本格式編寫文檔。要在網頁上顯示降價文檔,我們必須將降價文檔轉換為HTML文檔。
為了實現(xiàn)上述功能,我們的處理流程如下:
在了解了上面的處理流程之后,我們來使用 Node.js來實現(xiàn)解析 Markdown 文件的功能。
Users.md
parse-md.ts
在上面的代碼中,我們導入標記的模塊來實現(xiàn)Markdown文件的解析功能。之后,我們使用 esno 來執(zhí)行解析 md.ts 文件:
當上述代碼成功運行時,終端將輸出以下結果:
對于前兩個示例,盡管解析了不同類型的文件,但您會發(fā)現(xiàn)它們的解析過程是相似的。
整個過程主要包括三個步驟:讀取文件,解析文件和處理數(shù)據(jù)。對于此場景,我們可以引入模板方法模式來封裝上述三個步驟的處理順序。
模板方法模式由兩部分組成:抽象父類和具體實現(xiàn)子類。通常,子類的算法框架封裝在抽象父類中,它還包括一些公共方法的實現(xiàn)和封裝子類中所有方法的執(zhí)行順序。通過繼承此抽象類,子類還繼承整個算法結構,并且可以選擇重寫父類的方法。
接下來,讓我們看一下如何使用模板方法模式實現(xiàn) CSV 解析器和 Markdown 解析器。
為了更好地理解下面的代碼,我們先來看看相應的UML類圖:
在上圖中,我們定義了一個抽象類,然后分別定義了兩個子類和 。FileParser CsvParser MarkdownParser
文件解析器類
抽象類中的方法是所謂的模板方法,我們在其中封裝了文件處理的過程。parse FileParser
csvParser 類
MarkdownParser 類
使用 兩個類 和 ,我們可以通過以下方式解析 CSV 和標記文件
當您成功運行上面的代碼時,相應的輸出如下圖所示:
使用模板方法模式,我們重新實現(xiàn)了 CSV 和標記文件的解析。實際上,使用抽象類,我們可以輕松地開發(fā)不同的文件解析器。FileParser
最后,我們來總結一下模板方法模式的使用場景:
該算法的整體步驟非常固定,但是當單個部分是可變的時,此時可以使用模板方法模式來抽象易于可變的部分,以便實現(xiàn)子類。