NPM 使用介绍
NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种:
- 允许用户从NPM服务器下载别人编写的第三方包到本地使用。
- 允许用户从NPM服务器下载并安装别人编写的命令行程序到本地使用。
- 允许用户将自己编写的包或命令行程序上传到NPM服务器供别人使用。
由于新版的nodejs已经集成了npm,所以之前npm也一并安装好了。同样可以通过输入 "npm -v" 来测试是否成功安装。命令如下,出现版本提示表示安装成功:
$ npm -v
2.3.0
如果你安装的是旧版本的 npm,可以很容易得通过 npm 命令来升级,命令如下:
$ sudo npm install npm -g
/usr/local/bin/npm -> /usr/local/lib/node_modules/npm/bin/npm-cli.js
[email protected].14.2 /usr/local/lib/node_modules/npm
如果是 Window 系统使用以下命令即可:
npm install npm -g
使用 npm 命令安装模块
npm 安装 Node.js 模块语法格式如下:
$ npm install <Module Name>
以下实例,我们使用 npm 命令安装常用的 Node.js web框架模块 express:
$ npm install express
安装好之后,express 包就放在了工程目录下的 node_modules 目录中,因此在代码中只需要通过 require(‘express‘) 的方式就好,无需指定第三方包路径。
var express = require(‘express‘);
全局安装与本地安装
npm 的包安装分为本地安装(local)、全局安装(global)两种,从敲的命令行来看,差别只是有没有-g而已,比如
npm install express # 本地安装
npm install express -g # 全局安装
如果出现以下错误:
npm err! Error: connect ECONNREFUSED 127.0.0.1:8087
解决办法为:
$ npm config set proxy null
本地安装
- 1. 将安装包放在 ./node_modules 下(运行 npm 命令时所在的目录),如果没有 node_modules 目录,会在当前执行 npm 命令的目录下生成 node_modules 目录。
- 2. 可以通过 require() 来引入本地安装的包。
全局安装
- 1. 将安装包放在 /usr/local 下或者你 node 的安装目录。
- 2. 可以直接在命令行里使用。
如果你希望具备两者功能,则需要在两个地方安装它或使用 npm link。
接下来我们使用全局方式安装 express
$ npm install express -g
安装过程输出如下内容,第一行输出了模块的版本号及安装位置。
[email protected].13.3 node_modules/express
├── escape-[email protected].0.2
├── range-[email protected].0.2
├── merge-[email protected].0.0
├── array-[email protected].1.1
├── [email protected].1.3
├── utils-[email protected].0.0
├── [email protected].3.0
├── cookie-[email protected].0.6
├── [email protected].1.1
├── [email protected].3.0
├── [email protected].0.1
├── path-to-[email protected].1.7
├── content-[email protected].0.1
├── [email protected].7.0
├── serve-static@1.10.0
├── content-[email protected].5.0
├── [email protected].0.1
├── [email protected].0.0
├── [email protected].4.0 ([email protected].0.0)
├── on-[email protected].3.0 (ee-[email protected].1.1)
├── proxy-[email protected].0.8 ([email protected].1.0, ipaddr.[email protected].0.1)
├── [email protected].2.0 ([email protected].7.1)
├── type-is@1.6.8 (media-[email protected].3.0, mime-[email protected].1.6)
├── [email protected].2.12 ([email protected].5.3, mime-[email protected].1.6)
└── [email protected].13.0 ([email protected].0.3, [email protected].2.1, [email protected].7.1, [email protected].3.4, http-[email protected].3.1