理解Node.js安裝及模組化

  • 2019 年 10 月 6 日
  • 筆記

1.安裝Node

  • Node.js 是一個基於 Chrome V8 引擎的 JavaScript 運行環境。
  • Node.js 使用了一個事件驅動、非阻塞式 I/O 的模型,使其輕量又高效。
  • Node.js 的包管理器 npm(Node Package Manage),是全球最大的開源庫生態系統。

中文網:http://nodejs.cn/ 英文網:https://nodejs.org

2.REPL(互動式解釋器)

REPL(Read Eval Print Loop:互動式解釋器),表示一個電腦的環境,類似 Window 系統的終端或 Unix/Linux shell,我們可以在終端中輸入命令,並接收系統的響應。

Node 自帶了互動式解釋器,可以執行以下任務:

  • 讀取 – 讀取用戶輸入,解析輸入了Javascript 數據結構並存儲在記憶體中。
  • 執行 – 執行輸入的數據結構
  • 列印 – 輸出結果
  • 循環 – 循環操作以上步驟直到用戶兩次按下 ctrl-c 按鈕退出。

Node 的互動式解釋器可以很好的調試 Javascript 程式碼。我們可以輸入以下命令來啟動 Node 的終端:

$ node

這時我們就可以在>後輸入簡單的表達式,並按下回車鍵來計算結果。

3.使用變數

你可以將數據存儲在變數中,並在你需要的時候使用它。 變數聲明需要使用 var 關鍵字,如果沒有使用 var 關鍵字變數會直接列印出來。 使用 var 關鍵字的變數可以使用 console.log() 來輸出變數。

$ node      > x = 10      10      > var y = 10      undefined      > x + y      20      > console.log("Hello World")      Hello World      undefined      > console.log("www.runoob.com")      www.runoob.com      undefined

4.REPL 命令

  • ctrl+c – 按下一次,退出當前終端。
  • ctrl+c – 按下兩次,退出 Node REPL。
  • ctrl+d – 退出 Node REPL.
  • 向上/向下 – 查看輸入的歷史命令
  • tab 鍵 – 列出當前命令
  • .break – 結束當前會話,清空快取
  • .clear – .break 的別名,作用與 .break 相同
  • .editor – 開啟編輯器模式
  • .exit – 退出 REPL
  • .help – 列印幫助資訊
  • .load – 將文件中JS載入到 REPL
  • .save – 保存當前的 Node REPL 會話到指定文件

5.停止 REPL

前面我們已經提到按下兩次 ctrl + c 鍵就能退出 REPL:

$ node  >  (^C again to quit)  >

6.Node中的模組

在Node.js中,提供了一些核心模組,其中Node.js v8.4.0 版中的模組及其作用見下表:

  • assert – 斷言
  • Buffer – 緩衝器
  • child_process – 子進程
  • cluster – 集群
  • console – 控制台
  • crypto – 加密
  • dgram – 數據報
  • dns – 域名伺服器
  • Error – 異常
  • events – 事件
  • fs – 文件系統
  • global – 全局變數
  • http – HTTP
  • https – HTTPS
  • module – 模組
  • net – 網路
  • os – 作業系統
  • path – 路徑
  • process – 進程
  • querystring – 查詢字元串
  • readline – 逐行讀取
  • repl – 互動式解釋器
  • stream – 流
  • string_decoder – 字元串解碼器
  • timer – 定時器
  • tls – 安全傳輸層
  • tty – 終端
  • url – 網址
  • util – 實用工具
  • v8 – V8引擎
  • vm – 虛擬機
  • zlib – 壓縮

上面這些模組都屬於Node的核心模組,在使用這些模組時,不需要通過npm包管理器下載,直接就可以使用:

var http = require('http');

在這段程式碼中,使用require函數來引用http模組,該函數返回http模組對象,將該對象賦值給http變數之後,即可通過http變數來訪問http模組中的屬性及方法。

var http = require('http');  http.createServer(function (request, response){      response.writeHead(200, {'Content-Type': 'text/plain'});      response.end('Hello Worldn');  }).listen(8124, '127.0.0.1');

7.Node包管理器

NPM是隨同NodeJS一起安裝的包管理工具,能解決NodeJS程式碼部署上的很多問題,常見的使用場景有以下幾種:

  • 允許用戶從NPM伺服器下載別人編寫的第三方包到本地使用。
  • 允許用戶從NPM伺服器下載並安裝別人編寫的命令行程式到本地使用。
  • 允許用戶將自己編寫的包或命令行程式上傳到NPM伺服器供別人使用。

由於新版的nodejs已經集成了npm,所以Node安裝好之後,npm也一併安裝好了。我們可以通過輸入 「npm -v」 來測試是否成功安裝。命令如下,出現版本提示表示安裝成功:

npm -v  3.10.8

如果你安裝的是舊版本的 npm,可以通過 npm 命令來升級,命令如下:

npm install npm -g    7.1使用 npm 命令安裝模組

npm 安裝 Node.js 模組語法格式如下:

npm install <Module Name>

以下實例,我們使用 npm 命令安裝less:

npm install less

安裝好之後,less 包就放在了工程目錄下的 node_modules 目錄中,因此在程式碼中只需要通過 require(『less』) 的方式就好,無需指定第三方包路徑。var express = require('less');

8.全局安裝與本地安裝
npm 的包安裝分為本地安裝(local)、全局安裝(global)兩種,具體選擇哪種安裝方式取決於你想怎樣使用這個包。如果你想將它作為命令行工具使用,比如gulp-cli,那麼你可以全局安裝它。如果你要把它作為自己包的依賴,你可以局部安裝它。    8.1:本地安裝
npm install less          # 本地安裝
  1. 將安裝包放在 ./node_modules 下(運行 npm 命令時所在的目錄),如果沒有 node_modules 目錄,會在當前執行 npm 命令的目錄下生成 node_modules 目錄。
  2. 可以通過 require() 來引入本地安裝的包。

  8.2:全局安裝

  npm install less -g       # 全局安裝
  1. 將安裝包放在 /usr/local 下或者你 node 的安裝目錄。
  2. 可以直接在命令行里使用。

  如果你希望具備兩者功能,則需要在兩個地方安裝它或使用 npm link。

  8.3:查看安裝資訊

你可以使用以下命令來查看所有全局安裝的模組:

$ npm list -g    ├─┬ [email protected]  │ ├── [email protected]  │ ├── [email protected]  │ ├── [email protected]  │ ├─┬ [email protected]  │ │ └── [email protected]  │ ├─┬ [email protected]  │ │ └── [email protected]  ……

如果要查看某個模組的版本號,可以使用命令如下:

$ npm list grunt    projectName@projectVersion /path/to/project/folder  └── [email protected]

9.卸載模組

我們可以使用以下命令來卸載 Node.js 模組。

npm uninstall express

卸載後,你可以到 /node_modules/ 目錄下查看包是否還存在,或者使用以下命令查看:

npm ls      10:更新模組

我們可以使用以下命令更新模組:

npm update express    11.搜索模組

使用以下來搜索模組:

npm search express    12.創建模組
創建模組,package.json 文件是必不可少的。我們可以使用 NPM 生成 package.json 文件,生成的文件包含了基本的結果。

$ npm init    This utility will walk you through creating a package.json file.  It only covers the most common items, and tries to guess sensible defaults.    See `npm help json` for definitive documentation on these fields  and exactly what they do.    Use `npm install <pkg> --save` afterwards to install a package and  save it as a dependency in the package.json file.    Press ^C at any time to quit.  name: (code) nodedemo  version: (1.0.0)  description:  entry point: (load.js)  test command:  git repository:  keywords:  author:  license: (ISC)  About to write to E:html9前端9班第3階段課程3_NodeJScodepackage.json:    {    "name": "nodedemo",    "version": "1.0.0",    "description": "",    "main": "index.js",    "scripts": {      "test": "echo "Error: no test specified" && exit 1"    },    "author": "",    "license": "ISC"  }      Is this ok? (yes) yes

以上的資訊,你需要根據你自己的情況輸入。在最後輸入 「yes」 後會生成 package.json 文件。 接下來我們可以使用以下命令在 npm 資源庫中註冊用戶(使用郵箱註冊):

$ npm adduser  Username: mcmohd  Password:  Email: (this IS public) [email protected]

接下來我們就用以下命令來發布模組:

npm publish

如果你以上的步驟都操作正確,你就可以跟其他模組一樣使用 npm 來安裝。

13.cnpm淘寶鏡像

大家都知道中國直接使用 npm 的官方鏡像是非常慢的,這裡推薦使用淘寶 NPM 鏡像。淘寶 NPM 鏡像是一個完整 npmjs.org 鏡像,你可以用此代替官方版本(只讀),同步頻率目前為 10分鐘一次以保證盡量與官方服務同步。

你可以使用淘寶訂製的 cnpm (gzip 壓縮支援) 命令行工具代替默認的 npm:

npm install -g cnpm --registry=https://registry.npm.taobao.org

這樣就可以使用 cnpm 命令來安裝模組了:

cnpm install [name]

更多資訊可以查閱:http://npm.taobao.org/