五個Node.js開發(fā)的優(yōu)秀實踐
譯文?
??
【51CTO.com快譯】在這篇文章中,我們列出了5個通用的優(yōu)秀實踐,需要你在開發(fā)過程中牢記于心并盡可能的去實踐它們。
在Node.js開發(fā)時,請遵循以下5個最佳實踐。
1.分層組織代碼
例如Express.js這個應用廣泛的Node.js框架,它允許開發(fā)人員自定義回調函數(shù),當收到客戶端請求時回調函數(shù)執(zhí)行。有了這種靈活性,開發(fā)人員就可以非常方便地在回調函數(shù)中分析各種業(yè)務邏輯。
但是,如果你以寫回調函數(shù)作為學習Express.js起點的話,在你真正了解回調函數(shù)等這些原理之前,你會發(fā)現(xiàn)隨著開發(fā)的進行需要寫回調函數(shù)的情況越來越多,需要寫的回調函數(shù)的數(shù)量急劇增加,這讓你的路由文件變成了一堆笨重且混亂不堪的代碼。最差的情況就是代碼可讀性差,難以維護和管理,難以編寫單元測試用例。
為了避免這種情況的出現(xiàn),我們最好要踐行“關注點分離”的編程原則。這意味著應用開發(fā)中你要編寫不同的模塊來路由到你的不同的業(yè)務上。
對于后端程序開發(fā)來說,不同的客戶端請求就是通過不同的模塊或者層來處理的。
因此,我們可以把代碼分為三層來處理這些事情:
- Controller(路由層):這是定義API路由的代碼模塊。在路由處理函數(shù)中,可以解析請求對象,獲取必要的請求參數(shù),然后交給服務層進行處理。
- Serevice layer(服務層):由很多類和方法組成,并且這些類和方法只承擔單一職責,同時保證可用性。定義服務層能有效地將業(yè)務邏輯處理和路由定義解耦。
- Data access layer(數(shù)據(jù)訪問層):它主要負責數(shù)據(jù)庫的訪問,寫入和更新。所有的SQL語句,數(shù)據(jù)庫連接,模型,ORM等都應該在這里定義。
這種三層的代碼設計為大多數(shù)基于Node.js的應用開發(fā)提供了一個可靠的腳手架,讓我們的應用程序更易于編碼、維護、調試和測試。
2.使用代碼壓縮
Gzip作為一種無損的文件壓縮格式,主要用于壓縮文件進行更快地網(wǎng)絡傳輸。它在壓縮基于Node.js開發(fā)的Web應用代碼方面優(yōu)勢明顯。你知道Express.js可以很方便的進行Gzip格式的代碼壓縮嗎?沒錯,就是使用壓縮中間件。
另外,Express.js文檔建議使用如下代碼來提高應用的性能。
上面的這些設置會壓縮后端服務返回的響應體,并減少延遲,提高頁面的響應速度。
在優(yōu)化服務端性能時,前端代碼的優(yōu)化同樣至關重要。前端代碼上線前你需要了解網(wǎng)頁的大小。上線前不要忘了使用諸如HTMLMinifier, CSSNano和UglifyJS這樣的工具來壓縮前端HTML, CSS, JavaScript代碼。
總之,使用Gzip壓縮和精簡前端代碼是Node.js開發(fā)的優(yōu)秀實踐之一。
3.學會運用第三方解決方案
毫無疑問,Node.js擁有一個遍布全球的大型開發(fā)社區(qū)。圍繞NPM或Node的包管理器已經(jīng)有了很多功能豐富、維護良好、文檔完善的框架、庫和用于各種用例的工具。因此,開發(fā)人員可以方便地在項目中使用這些現(xiàn)有的解決方案,并充分利用這些API。
強烈建議你去尋找一些現(xiàn)有的解決方案來處理遇到的問題,這會讓你的開發(fā)工作更容易。下面是一些流行的Node.js庫,可以有效的改善你的代碼質量:
- Gulp:一個自動化的任務構建工具。
- Agenda:一個輕量級任務調度庫。
- Moment:一個解析,校驗,操作,顯示日期時間的工具庫。
- Winston:一個日志記錄框架。
- Nodemon:一個可以監(jiān)聽文件變更,自動重啟服務的工具。
上面的這些庫和工具可以讓開發(fā)者更輕松地應對各種問題。不過,非常關鍵的的一點是你需要對項目中每一個導入的包有足夠的認知并為此負責。此外,你還應該知道導入的每個包的目的是什么,有什么優(yōu)勢,有哪些缺點和問題。最后,作為一個開發(fā)者,你要確保不會過度依賴這些第三方庫包。
4.充分利用程序監(jiān)控工具
APM工具負責通過發(fā)現(xiàn)瓶頸和修復錯誤來監(jiān)視應用程序的性能和可用性。Node.js監(jiān)控工具可以通過分析每個Web結果來修復Bug,指出問題并跟蹤問題。
使用APM工具的主要目的之一是評估性能指標、質量問題、性能瓶頸、標準錯誤等,并利用得到的這些信息來進行所需的代碼修改和改進。
ScoutAPM就是一個APM工具,可以幫助開發(fā)者分析和優(yōu)化網(wǎng)頁應用的性能。它還提供了實時監(jiān)控,能幫助開發(fā)者快速地定位問題,并在最終確定問題之前進行更改以解決問題。
此APM工具是唯一一個應用程序性能監(jiān)視產(chǎn)品,它克服了諸如提高性能和穩(wěn)定性等問題。其中N+1數(shù)據(jù)庫查詢、數(shù)據(jù)庫慢查詢和性能異常是最常見的問題。
5.保持你的代碼整潔且易于復用
代碼檢查和格式化
你所需要做的就是不斷提高代碼質量和代碼的可讀性。為了實現(xiàn)這些,需要壓縮代碼,這有助于減少延遲,提高網(wǎng)頁響應速度。大多數(shù)代碼開發(fā)流程通常包含一個代碼檢查和代碼格式化的過程。
不過代碼檢查器只能處理代碼中不完美的地方,并且只有一種方法來修復它們。另一方面,代碼格式化程序的工作目標是確定一組格式和樣式指導原則,這些指導原則必須在整個項目中保持一致。
ESLint,JSLint和HSHint是最常用的JavaScript代碼檢查工具,Prettier是最常用的代碼格式化工具。這些工具并不關注代碼的具體含義,只關心代碼的格式,規(guī)范性。幸運的是,大多數(shù)IDE或者代碼編輯器如Visual Studio code(VSCode),Atom等,都認可編寫高質量代碼的重要性,并提供了代碼檢測和格式化插件,并且這些插件都非常容易設置。
此外,一些IDE還提供了一些有用的特性,如智能代碼補全、Debug調試工具、代碼跳轉和代碼格式優(yōu)化等。這些工具還是有不少優(yōu)點的,因此強烈建議寫代碼時使用上這樣的IDE設置。
代碼風格指南
你需要遵循的另一個優(yōu)秀實踐是參考谷歌和Airbnb等巨頭使用的JavaScript代碼風格指南和標準。這些指導原則涵蓋了從文件、變量和類的命名約定到文件編碼的格式細節(jié)等等。更重要的是:它可以幫助你編寫高質量的代碼,并且這些代碼風格符合一些全球頂級開發(fā)人員使用的實踐和標準。
總結
我們試著描述出在開發(fā)過程中,你應該考慮到的最重要的優(yōu)秀實踐,以避免工作進展沒多少就遇到很多困難和挑戰(zhàn)。請記住:雇傭一支專業(yè)的Node.js開發(fā)團隊永遠是一個好主意,這不僅會幫助你寫出整潔高質量的代碼,還會在開發(fā)的方方面面幫助到你。
最后我們想對開發(fā)人員們說的是:是時候把你在今天學到的內容應用到你項目中去了。堅持去踐行這些優(yōu)秀實踐,你就一定會從中受益,開發(fā)出高可用、可伸縮的Node.js應用程序。
譯者介紹
盧鑫旺,51CTO社區(qū)編輯,半路出家的九零后程序員。做過前端頁面,寫過業(yè)務接口,搞過爬蟲,研究過JS,有幸接觸Golang,參與微服務架構轉型。目前主寫Java,負責公司可定制化低代碼平臺的數(shù)據(jù)引擎層設計開發(fā)工作。
原文標題:5 Best Practices to Follow for Node.js Development,作者:Hiren Dhaduk
【51CTO譯稿,合作站點轉載請注明原文譯者和出處為51CTO.com】






























