使用 Fastify 框架以及 TypeScript 語言來開發 Web 服務的起手式 2022 年 11 月 24 日 Magic Len NodeJS Fastify是一個運行在Node.js上的Web框架,注重開發體驗和低開支(overhead),提供完整的Web框架特性,但也保有良好的效能,效能要比Express框架還好上不少。Fastify支援TypeScript語言,筆者建議使用TypeScript來開發Fastify應用程式。然而,要建立出一個完整TypeScript專案是一件繁瑣的事情,我們會需要安裝多種套件及工具並撰寫設定檔和程式碼... 繼續閱讀
如何寫程式處理中華民國的身份證字號? 2022 年 11 月 22 日 Magic Len 研究分享、 NodeJS、 Rust 中華民國的「身份證字號」,正式名稱為「國民身分證統一編號」,是由一個代表出生地的大寫英文字母加上九個數字所組成。雖然《戶籍法》第五十七條第一項規定「年滿十四歲者,應申請初領國民身分證;未滿十四歲者,得申請發給」,但國民就算沒有國民身份證,在出生之後報戶口就會有身份證字號了。當然,台灣不是只有本地國民而已,也存在著他國國籍的人,這類人所使用的相關編號,為了能夠方便在現有的系統中使用,已於西元2021... 繼續閱讀
[LeetCode]移除元素(Remove Element) 2022 年 11 月 19 日 Magic Len 程式解題、 NodeJS、 Rust 給定一個「nums」整數陣列和一個「val」整數,用原地(in-place)的方式移除其中所有值為的「val」元素。元素的相對位置可能會改變。 繼續閱讀
[LeetCode]移除已排序陣列中的重複元素(Remove Duplicates from Sorted Array) 2022 年 11 月 12 日 Magic Len 程式解題、 NodeJS、 Rust 給定一個遞增排序的「nums」整數陣列,用原地(in-place)的方式移除重複的元素,使每個元素都是獨特的,也就是只會出現一次。元素的相對位置在處理後應保持相同。 繼續閱讀
建立 TypeScript 專案的起手式 2022 年 11 月 10 日 Magic Len NodeJS JavaScript有著資源豐富的生態圈,但同時也令人在面對這一堆套件、工具以及設定時眼花撩亂、不知所措。TypeScript能用比較嚴謹的方式來開發JavaScript程式,可以大大地提升程式碼的可維護性,也可以增加多人協作時的效率。筆者甚至覺得我們都應該用TypeScript來編寫JavaScript程式會比較好。然而,要建立出一個完整TypeScript專案是一件繁瑣的事情,我們會需要安裝多... 繼續閱讀
[LeetCode]兩兩加總(Two Sum) 2022 年 11 月 5 日 Magic Len 程式解題、 NodeJS、 Rust 給定一個「nums」整數陣列和一個整數「target」,回傳加總會等於「target」的兩個不同的元素的索引值。 繼續閱讀
如何在Webpack中使用TypeScript? 2020 年 1 月 14 日 Magic Len NodeJS Webpack是JavaScript的模組建置工具,運行在Node.js上,它可以將零散的JavaScript檔案用各式工具優化並打包起來,加快網頁的載入時間。Webpack也並不限於用在JavaScript上,它除了還能打包網頁有用到的靜態資源(如JS、CSS、圖片檔等)外,也還能透過TypeScript的載入器(loader)來編譯並打包TypeScript程式碼。 繼續閱讀
TypeScript 學習之路─第十八章:裝飾器(Decorator) 2020 年 1 月 9 日 Magic Len 研究分享、 NodeJS 裝飾器(Decorator)是一種程式設計模式(Design Pattern),在某些情況下可以用來替代繼承(inheritance),以更靈活、輕量的方式重用程式碼。 繼續閱讀
TypeScript 學習之路─第十七章:命名空間(namespace) 2020 年 1 月 7 日 Magic Len 研究分享、 NodeJS JavaScript如果要替名稱加上命名空間,不外乎就是利用物件或是模組來達成。但在TypeScript中,有「namespace」關鍵字可以讓我們快速地新增命名空間來用。 繼續閱讀
TypeScript 學習之路─第十六章:模組 2020 年 1 月 2 日 Magic Len 研究分享、 NodeJS 我們先前所練習的TypeScript程式幾乎都只是把程式敘述寫在「index.ts」檔案中,雖然我們已經會使用函數、類別來分割不同功能的程式,但當程式愈寫愈多的時候,這樣的作法還是會讓程式變得難以維護。這時就需要用到TypeScript提供的「模組」系統了。 繼續閱讀