千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 設(shè)計(jì)模式:類(lèi)型腳本中的模板方法模式

設(shè)計(jì)模式:類(lèi)型腳本中的模板方法模式

來(lái)源:千鋒教育
發(fā)布人:syq
時(shí)間: 2022-09-13 15:12:32 1663053152

  歡迎來(lái)到“類(lèi)型腳本中的設(shè)計(jì)模式”系列,它介紹了使用類(lèi)型腳本進(jìn)行 Web 開(kāi)發(fā)中的一些有用的設(shè)計(jì)模式。

類(lèi)型腳本中的模板方法模式

  設(shè)計(jì)模式對(duì)于Web開(kāi)發(fā)人員來(lái)說(shuō)非常重要,我們可以通過(guò)掌握它們來(lái)編寫(xiě)更好的代碼。在本文中,我將使用類(lèi)型腳本來(lái)介紹模板方法模式。

  CSV(逗號(hào)分隔值)是一種通用的、相對(duì)簡(jiǎn)單的文件格式。CSV 文件以純文本形式存儲(chǔ)表格數(shù)據(jù)(數(shù)字和文本)。當(dāng)您需要處理CSV數(shù)據(jù)時(shí),對(duì)應(yīng)的處理流程如下圖所示:

  在了解了上面的處理流程之后,讓我們使用 Node.js來(lái)實(shí)現(xiàn)解析 csv 文件的功能。

  用戶(hù).csv

1

  parse-csv.ts

2

  在上面的代碼中,我們導(dǎo)入 d3-dsv 模塊來(lái)實(shí)現(xiàn) csv 的解析功能。之后,我們使用 esno 來(lái)執(zhí)行解析 cvs.ts 文件:

3

  當(dāng)上述代碼成功運(yùn)行時(shí),終端將輸出以下結(jié)果:

4

  Markdown是一種輕量級(jí)標(biāo)記語(yǔ)言,允許人們以易于閱讀和寫(xiě)入的純文本格式編寫(xiě)文檔。要在網(wǎng)頁(yè)上顯示降價(jià)文檔,我們必須將降價(jià)文檔轉(zhuǎn)換為HTML文檔。

  為了實(shí)現(xiàn)上述功能,我們的處理流程如下:

5

  在了解了上面的處理流程之后,我們來(lái)使用 Node.js來(lái)實(shí)現(xiàn)解析 Markdown 文件的功能。

  Users.md

6

  parse-md.ts

7

  在上面的代碼中,我們導(dǎo)入標(biāo)記的模塊來(lái)實(shí)現(xiàn)Markdown文件的解析功能。之后,我們使用 esno 來(lái)執(zhí)行解析 md.ts 文件:

8

  當(dāng)上述代碼成功運(yùn)行時(shí),終端將輸出以下結(jié)果:

9

  對(duì)于前兩個(gè)示例,盡管解析了不同類(lèi)型的文件,但您會(huì)發(fā)現(xiàn)它們的解析過(guò)程是相似的。

10

  整個(gè)過(guò)程主要包括三個(gè)步驟:讀取文件,解析文件和處理數(shù)據(jù)。對(duì)于此場(chǎng)景,我們可以引入模板方法模式來(lái)封裝上述三個(gè)步驟的處理順序。

  模板方法模式由兩部分組成:抽象父類(lèi)和具體實(shí)現(xiàn)子類(lèi)。通常,子類(lèi)的算法框架封裝在抽象父類(lèi)中,它還包括一些公共方法的實(shí)現(xiàn)和封裝子類(lèi)中所有方法的執(zhí)行順序。通過(guò)繼承此抽象類(lèi),子類(lèi)還繼承整個(gè)算法結(jié)構(gòu),并且可以選擇重寫(xiě)父類(lèi)的方法。

  接下來(lái),讓我們看一下如何使用模板方法模式實(shí)現(xiàn) CSV 解析器和 Markdown 解析器。

  為了更好地理解下面的代碼,我們先來(lái)看看相應(yīng)的UML類(lèi)圖:

11

  在上圖中,我們定義了一個(gè)抽象類(lèi),然后分別定義了兩個(gè)子類(lèi)和 。FileParser CsvParser MarkdownParser

  文件解析器類(lèi)

13

  抽象類(lèi)中的方法是所謂的模板方法,我們?cè)谄渲蟹庋b了文件處理的過(guò)程。parse FileParser

  csvParser 類(lèi)

15

  MarkdownParser 類(lèi)

16

  使用 兩個(gè)類(lèi) 和 ,我們可以通過(guò)以下方式解析 CSV 和標(biāo)記文件

17

  當(dāng)您成功運(yùn)行上面的代碼時(shí),相應(yīng)的輸出如下圖所示:

18

  使用模板方法模式,我們重新實(shí)現(xiàn)了 CSV 和標(biāo)記文件的解析。實(shí)際上,使用抽象類(lèi),我們可以輕松地開(kāi)發(fā)不同的文件解析器。FileParser

  最后,我們來(lái)總結(jié)一下模板方法模式的使用場(chǎng)景:

  該算法的整體步驟非常固定,但是當(dāng)單個(gè)部分是可變的時(shí),此時(shí)可以使用模板方法模式來(lái)抽象易于可變的部分,以便實(shí)現(xiàn)子類(lèi)。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
軟件定制開(kāi)發(fā)中的敏捷開(kāi)發(fā)是什么?

軟件定制開(kāi)發(fā)中的敏捷開(kāi)發(fā)是什么軟件定制開(kāi)發(fā)中的敏捷開(kāi)發(fā),從宏觀上看,是一個(gè)高度關(guān)注人員交互,持續(xù)開(kāi)發(fā)與交付,接受需求變更并適應(yīng)環(huán)境變化...詳情>>

2023-10-14 13:24:57
什么是PlatformIo?

PlatformIO是什么PlatformIO是一個(gè)全面的物聯(lián)網(wǎng)開(kāi)發(fā)平臺(tái),它為眾多硬件平臺(tái)和開(kāi)發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡(jiǎn)化了開(kāi)發(fā)過(guò)程,并能兼容各種...詳情>>

2023-10-14 12:55:06
云快照與自動(dòng)備份有什么區(qū)別?

1、定義和目標(biāo)不同云快照的主要目標(biāo)是提供一種快速恢復(fù)數(shù)據(jù)的方法,它只記錄在快照時(shí)間點(diǎn)后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動(dòng)備份的主要目標(biāo)...詳情>>

2023-10-14 12:48:59
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢(shì)和特點(diǎn)。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問(wèn)題是什么?

ORM(對(duì)象關(guān)系映射)解決的主要問(wèn)題是將關(guān)系數(shù)據(jù)庫(kù)與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫(kù)中,數(shù)據(jù)以表格的形式存儲(chǔ),而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
快速通道
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
最新69国产精品视频免费 | 在线不卡的午夜福利 | 一区二区三区韩国电影 | 日本综合另类欧美日韩 | 亚洲一区二区制服在线 | 性做久久久久久久免费看 |