成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

10個技巧,讓你在 2017 年成為更好的Node開發者

開發 前端
在2012年,我加入了Storify并開始使用Node作為我的主要語言。從那以后,我從未回首過去并覺得我錯過了Python,Ruby,Java以及PHP,這些在過去10年里,我在web開發過程中使用的語言。

在2012年,我加入了Storify并開始使用Node作為我的主要語言。從那以后,我從未回首過去并覺得我錯過了Python,Ruby,Java以及PHP,這些在過去10年里,我在web開發過程中使用的語言。下面我將列出10條建議,這些建議可以幫助你在2017年成為一個更好的Node開發者。其中一些建議是我在日常實踐中所學到的,另一些是從那些寫了最流行的Node和npm模塊的人們身上學到的。 下面是我們將要介紹的內容:

[[183010]]

本文是由我們的客座作者Azat Mardan寫的。SitePoint引入客座帖子的目的是希望能給你帶來web社區里著名作者和演講者的有趣內容。

在2012年,我加入了Storify并開始使用Node作為我的主要語言。從那以后,我從未回首過去并覺得我錯過了Python,Ruby,Java以及PHP,這些在過去10年里,我在web開發過程中使用的語言。

Storify提供給我一個很有趣的工作,因為Storify和其他的公司不太一樣,Storify之前(可能到現在也是)所有的代碼都是由JavaScript編寫的。而大多數公司,特別是大公司,例如PayPal,Walmart(沃爾瑪)或者Capital One(第一資本),只是在某一些特定的部分使用了Node。通常,他們使用Node作為API接口或者用在業務流程層,這樣做是很好的。但是作為一個軟件工程師,沒什么比得上能夠完全沉浸在Node環境里。

下面我將列出10條建議,這些建議可以幫助你在2017年成為一個更好的Node開發者。其中一些建議是我在日常實踐中所學到的,另一些是從那些寫了最流行的Node和npm模塊的人們身上學到的。 下面是我們將要介紹的內容:

  1. 避免復雜性 — 盡可能將你的代碼塊拆到最小,要小到極致。

  2. 使用異步編程 — 像躲避瘟疫般避免使用同步代碼。

  3. 避免require阻塞 — 把你所有的require聲明都放在文件的頂部,因為require是同步的,會阻塞代碼運行。

  4. 了解require緩存 — 了解它則可以利用它,否則它可能會帶來bug。

  5. 始終檢查錯誤 — 錯誤不是足球,任何時候都不要拋出錯誤或者跳過錯誤檢查。

  6. 只在同步代碼中使用try…catch — 在異步代碼中try...catch是沒有作用的。V8引擎針對try...catch無法進行優化。

  7. 返回callbacks或者使用if … else — 返回一個callback只是為了確保不繼續執行。

  8. 監聽錯誤事件 — 幾乎所有的Node的類/對象都有event emitter(觀察者模式)并且會廣播error事件,確保你監聽了它們。

  9. 了解你的npm — 使用-S或者-D來安裝模塊來代替--save或者--save-dev`。

  10. 在package.json中使用精確的版本號: npm在使用-S來安裝模塊時會自動使用默認的版本號,你需要手動修改去鎖定版本號。除非是開源模塊,否者不要相信你的項目中的SemVer(語義化版本標準)。

  11. 加分 — 使用不同的依賴。把項目在開發階段需要的東西放在 devDependencies 中,記得使用 npm i --production。多余的依賴越多,出現問題的風險就越大。

好的,接下來讓我們一個個單獨地去了解上面的每一點。

避免復雜性

讓我看一眼npm的創造者Isaac Z. Schlueter寫的一些模塊,例如,use-strict,這個模塊是用來在Javascript中強制使用嚴格模式,這個模塊僅僅只有三行代碼:

微信截圖_20170206141432.png

所以我們為什么要避免復雜性呢? 一個起源于美國海軍的著名短語:KEEP IT SIMPLE STUPID(或者是“Keep it simple, stupid”)。這就是原因。事實說明,人類大腦在任何一個時間只能在其工作記憶中保持五到七個項目。

把你的代碼模塊化成一個更加小的部分,你和其他的開發者會更加好的理解它。你也可以更加好的去測試它。如下例子,

或者是

我相信大多數人都會喜歡第二個例子,特別是光看名字就能了解其作用。當日,在你編寫代碼的時候,你可能認為你知道代碼是如何運行的。甚至你想要展示你把幾個功能連接在一起寫在同一行中是多么的機智。但是,這樣你是寫了一段愚蠢的代碼。如果你思考的很復雜去寫這代碼,那么今后你再去看這段代碼將會很難去理解。保證你的代碼簡單,特別是在Node的異步代碼中。

當然也會有left-pad 事件,但是其實它只是影響了依賴于left-pad模塊的項目而且11分鐘后就發布了替代品。代碼的最小化帶來的好處超過了它的缺點。npm已經改變了發布策略,任何重要的項目都應該使用緩存或私有的源(作為臨時解決方案)。

使用異步編程

在Node中同步代碼只要很小的一部分。這些代碼大多數都是用于命令行工具或者其他與web應用無關的腳本。Node開發者大多數都是編寫web應用,因此使用異步代碼可以避免阻塞現場。

例如,當你在編寫一個數據庫的腳本或者是一個不需要控制并行的任務時,下面這種寫法可能是可以的:

但是當你創建一個web應用時,下面這個寫法會更好:

這個區別在于你是否需要編寫一個并發(通常是長期運行)或者非并發(短期運行)的系統。根據經驗來說,總是要在Node中使用異步代碼。

避免require阻塞

Node有一個使用了CommonJS模塊格式的簡單的模塊加載系統。它是基于require函數,require函數可以很方便的在不同的文件中引入模塊。和AMD/requirejs不同,Node/CommonJS的模塊加載時同步的。require的工作方式是:引入一個模塊或者一個文件export的內容:

微信截圖_20170206141653.png

但是大多數的開發者并不知道require是會被緩存的。因此,只要解析的文件名(resolved filename)沒有劇烈的變化(比如npm模塊不存在的情況),模塊的代碼只會被執行并存入變量中一次(在當前進程中)。這是一個很好的優化。當然,即使有了緩存,你最好還是把你的require聲明寫在開頭。下面這段代碼,它在路由中真正使用到了axios模塊的時候才加載。當請求發送的時候/connect會因為需要加載模塊所以會變得慢。

一個更好,性能更優的方式是在服務定義之前就引入模塊而不是在路由中:

知道require會被緩存

我在上面一節已經提到了require會被緩存,但是有趣的是我們在module.exports之外也會有代碼。舉例來說:

[[183013]]

從中我們了解到有一些代碼只會運行一次,你可以使用這個特性來優化你的代碼。

始終檢查錯誤

Node不是Java。在Java中,你可以拋出錯誤,因為如果發生了錯誤那么你會希望應用不在繼續執行。在Java中,你可以在外層僅僅使用一個簡單的try...catch就可以處理多個錯誤。

但是在Node中并不是這樣的。自從Node使用了事件循環和異步執行后,任何的錯誤發生時都會與錯誤處理器(例如try...catch)的上下文分離,下面這樣做在Node中是沒有用的:

但是try...catch在同步代碼中是可以被用的。前面的代碼片段可以被更好的重構為:

如果我們無法將request的返回內容包裹在try...catch中,那么我們將沒有辦法去處理請求的錯誤。Node的開發者通過在返回的參數里面加上error來解決了這個問題。因此,我們需要在每一個回調中手動去處理錯誤。你可以去檢查這些錯誤(判斷error不是null),然后展示錯誤信息給用戶或者展示在客戶端上并且記錄它, 或者你可以通過調用 callback ,給它傳 error 參數,將錯誤傳回給上一級調用棧(如果你在調用棧之上有另一個回調函數)。

一個小技巧是你可以使用okay庫。你可以像下面的例子一樣使用它去避免在回調地獄中手動去檢查錯誤(你好, 回調地獄).

返回回調或者使用if … else

Node是并行的。但是如果你不夠細心也會因為這個特性產生bug。 為了安全起見,應該要使用return來終止代碼的繼續執行:

這樣可以避免一些因為代碼邏輯的處理不當導致一些不應該執行的內容(或者錯誤)被執行。

請確保使用return去阻止代碼的繼續執行。

監聽 error 事件

Node中幾乎所有的類/對象都有事件分發器(觀察者模式)并且會廣播 error 事件。 這是一個很好的特性,可以使開發者在這些討厭的錯誤造成巨大后果之前捕捉到它們。

養成一個通過.on()來創建error事件監聽的好習慣:

了解你的npm

很多的Node和前端的開發者知道在安裝模塊的時候使用--save會在安裝模塊的同時,會在package.json保存一條含有模塊版本信息的條目。當然,還有--save-dev可以用于安裝devDependencies(在生成環境中不需要的模塊)。但是你知道用-S和-D是否可以代替--save 和--save-dev么?答案是可以的。

當你安裝模塊的時候,你需要刪除-S和-D自動為你模塊的版本號添加的^標簽。否者當你使用npm install(或者npm i)安裝模塊的時候,就會自動拉取最新的鏡像(版本號的第二位數字)。例如v6.1.0就是v6.2.0的一個鏡像分支。

npm團隊推薦使用semver,但是你最好不要這樣。npm團隊認為開源開發者會遵守semver所以他們在npm安裝時自動加上了^。沒有人可以去保證,所以最好是鎖定你的版本號。更好的辦法是使用shrinkwrap:npm shrinkwrap會生成一個包含依賴的具體版本的文件。

 

責任編輯:張燕妮 來源: 齊舞周刊
相關推薦

2020-03-31 09:47:04

Vue開發代碼

2016-01-21 10:58:41

Node.js開發者

2023-03-27 23:57:25

JavaScrip開發技巧

2022-06-23 09:22:57

Vue技巧前端

2022-12-07 15:01:47

2022-06-08 08:55:15

JavaScript代碼前端

2024-02-28 07:48:05

Rust項目框架

2011-12-27 09:31:13

程序員

2024-12-31 00:12:39

命令Docker網絡

2013-06-07 10:07:28

開發者優秀開發者

2014-08-20 10:02:54

GitGit能力

2020-06-15 10:29:10

JavaScript開發 技巧

2022-07-18 10:15:16

Python

2015-08-11 11:01:22

設計原則開發者

2024-08-09 15:01:00

2025-02-13 12:52:27

JavaScrip代碼開發

2017-08-29 14:50:41

Android開發者專業性建議

2017-01-16 13:15:19

前端開發者清單

2014-10-09 09:29:25

AngularJS

2015-04-21 12:54:21

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久久免费精品国产小说色大师 | 欧美激情精品久久久久 | 性色av网站 | 欧美 中文字幕 | 成人av网站在线观看 | 在线观看欧美一区 | 成人av免费 | 91私密视频 | 国产色网 | 亚洲欧洲一区 | 亚洲精品国产成人 | 亚洲精品91 | 超碰超碰 | 91高清免费观看 | 国产视频91在线 | 九九九色| 麻豆视频在线免费观看 | 91婷婷韩国欧美一区二区 | 亚洲视频二区 | 亚洲国产激情 | 色狠狠一区 | 99精品国自产在线 | 久久999| 中文日本在线 | 国产综合久久 | 日韩欧美国产精品 | 国产高清美女一级a毛片久久w | 91视视频在线观看入口直接观看 | 日韩免费高清视频 | 亚洲码欧美码一区二区三区 | 九一在线观看 | 欧美综合一区二区三区 | 二区精品 | 日韩精品无码一区二区三区 | 欧美成人精品一区二区男人看 | 久久国产区 | 亚洲草草视频 | av在线一区二区三区 | 91精品国产91久久久久久 | 亚洲午夜av久久乱码 | 99国产精品99久久久久久 |