如果你安装的是旧版本的 npm,可以很容易得通过 npm 命令来升级,命令如下:
$ sudo npm install npm -g
如果是 Window 系统使用以下命令即可:
npm install npm -g
使用淘宝镜像的命令:
npm install -g cnpm --registry=https://registry.npm.taobao.org
你可以使用以下命令来查看所有全局安装的模块:$ npm list -g
如果要查看某个模块的版本号,可以使用命令如下:$ npm list grunt
更换仓库源:
npm config set registry https://registry.npm.taobao.org/
查看配置:npm config ls
设置本地仓库地址:npm config set prefix “D:\xx” 【更改了npm本地仓库地址,需要配置环境变量PATH,这样npm下载的工具才能任意目录使用】
设置本地缓存地址:npm config set cache “D:\xx”
设置代理
npm config set proxy http://server:port
npm config set https-proxy http://server:port
打开.npmrc文件
npm config edit
npm install 流程
npm i package --timing=true --loglevel=verbose 命令可以看到 npm install 的完整过程,
在执行 npm install 或 npm update命令下载依赖后,除了将依赖包安装在node_modules 目录下外,还会在本地的缓存目录缓存一份。通过 npm config get cache 命令可以查询到
也可以使用命令 yarn cache dir
yarn 默认使用 prefer-online 模式,即优先使用网络数据,如果网络数据请求失败,再去请求缓存数据。
Package.json 属性说明
• name - 包名。
• version - 包的版本号。
• description - 包的描述。
• homepage - 包的官网 url 。
• author - 包的作者姓名。
• contributors - 包的其他贡献者姓名。
• dependencies - 依赖包列表。如果依赖包没有安装,npm 会自动将依赖包安装在 node_module 目录下。
• repository - 包代码存放的地方的类型,可以是 git 或 svn,git 可在 Github 上。
• main - main 字段指定了程序的主入口文件,require(‘moduleName’) 就会加载这个文件。这个字段的默认值是模块根目录下面的 index.js。
• keywords - 关键字
package-lock.json作用。
以下两种情形:
1、升级了一些依赖,并在package.json更新,此时package-lock.json肯定还是原来的版本信息 --------> 这时候其他人去安装依赖是按最新的版本安装的,并更新package-lock.json
2、升级了一些依赖,并未在package.json里更新,此时package-lock.json还是和package.json一样 ---------> 这时候其他人去安装依赖就还是以前的老版本。
npm install 【插件名】或 npm install 【插件名】–save 归属dependencies,表示代码运行时所需要的包。
npm install 【插件名】–save-dev 归属 devDependencies,表示开发时依赖的插件(即不会打包至线上)。
npm install将同时安装“ dependencies ”和“ devDependencies ”
npm install --production将仅安装“ 依赖项 ”
npm install --dev将仅安装“ devDependencies ”
卸载模块
• 我们可以使用以下命令来卸载 Node.js 模块。
• $ npm uninstall express
• 卸载后,你可以到 /node_modules/ 目录下查看包是否还存在,或者使用以下命令查看:
• $ npm ls
• 更新模块
• 我们可以使用以下命令更新模块:
• $ npm update express
• 搜索模块
• 使用以下来搜索模块:
• $ npm search express
创建模块
创建模块,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: (node_modules) runoob # 模块名
version: (1.0.0)
description: Node.js 测试模块(www.runoob.com) # 描述
entry point: (index.js)
test command: make test
git repository: https://github.com/runoob/runoob.git # Github 地址
keywords:
author:
license: (ISC)
About to write to ……/node_modules/package.json: # 生成地址
{
"name": "runoob",
"version": "1.0.0",
"description": "Node.js 测试模块(www.runoob.com)",
……
}
Is this ok? (yes) yes
以上的信息,你需要根据你自己的情况输入。在最后输入 “yes” 后会生成 package.json 文件。
接下来我们可以使用以下命令在 npm 资源库中注册用户(使用邮箱注册):
$ npm adduser
Username: mcmohd
Password:
Email: (this IS public) mcmohd@gmail.com
接下来我们就用以下命令来发布模块:
$ npm publish
如果你以上的步骤都操作正确,你就可以跟其他模块一样使用 npm 来安装。
版本号
使用NPM下载和发布代码时都会接触到版本号。NPM使用语义版本号来管理代码,这里简单介绍一下。
语义版本号分为X.Y.Z三位,分别代表主版本号、次版本号和补丁版本号。当代码变更时,版本号按以下原则更新。
• 如果只是修复bug,需要更新Z位。
• 如果是新增了功能,但是向下兼容,需要更新Y位。
• 如果有大变动,向下不兼容,需要更新X位。
版本号有了这个保证后,在申明第三方包依赖时,除了可依赖于一个固定版本号外,还可依赖于某个范围的版本号。例如"argv": "0.0.x"表示依赖于0.0.x系列的最新版argv。
NPM支持的所有版本号范围指定方式可以查看官方文档。
• ~ 会匹配最近的小版本依赖包,比如~1.2.3会匹配所有1.2.x版本,但是不包括1.3.0
• ^ 会匹配最新的大版本依赖包,比如^1.2.3会匹配所有1.x.x的包,包括1.3.0,但是不包括2.0.0
• * 这意味着安装最新版本的依赖包
NPM 常用命令
除了本章介绍的部分外,NPM还提供了很多功能,package.json里也有很多其它有用的字段。
除了可以在npmjs.org/doc/查看官方文档外,这里再介绍一些NPM常用命令。
NPM提供了很多命令,例如install和publish,使用npm help可查看所有命令。
• NPM提供了很多命令,例如install和publish,使用npm help可查看所有命令。
• 使用npm help 可查看某条命令的详细帮助,例如npm help install。
• 在package.json所在目录下使用npm install . -g可先在本地安装当前命令行程序,可用于发布前的本地测试。
• 使用npm update 可以把当前目录下node_modules子目录里边的对应模块更新至最新版本。
• 使用npm update -g可以把全局安装的对应命令行程序更新至最新版。
• 使用npm cache clear可以清空NPM本地缓存,用于对付使用相同版本号发布新版本代码的人。
• 使用npm unpublish @可以撤销发布自己发布过的某个版本代码。
• npm config get prefix 查看全局安装路径