简介

随着前端模块化时代的到来,花样百出的第三方模块奔涌而出,相对应的就会出现包管理工具。在java中有maven,那么在前端就有npm

下载安装

由于npm被集成在nodeJs里面,所以我们想要使用npm 就必须要安装nodejs

  1. 运行nodeJs安装程序,一路选择默认配置安装即可,它会将nodeJs加入环境变量中,不需要我们操心
  1. 安装完成之后我们可以使用 node -v npm -v 来查看当前nodeJs以及npm版本号

    如果此时版本号能被正常打印出来,就说明我们安装就到此完成了
    如果提示 “node”不是内部或外部命令,也不是可运行的程序 或批处理文件,则需要重启电脑,若是重启之后依然提示错误,就需要到下一步,配置环境变量

配置环境变量

首先来到node安装目录下,在此处打开命令行窗口,执行 node -v

如果版本号能够被正常打印出来,则说明nodejs只能在当前安装目录使用,不能在此路径之外使用,此时则需要配置全局环境变量

如图所示,添加环境变量即可正常使用npm了

配置模块安装位置

既然是一个包管理工具,那么它最大的作用就是下载各种第三方模块,那么它下载的包在哪里呢

在Window7,8,10 中,当全局安装时,包的默认下载路径是
C:\Users\[UsersName]\AppData\Roaming\npm\node_modules,如果它安装在C盘的话会造成我们的一些不方便,所以我们可以修改默认安装路径

使用 npm config set prefix "url"命令来设置默认全局安装路径,双引号中的url就是你想要安装的路径,全局安装的路径需要再配置到环境变量中

同时我们也可以通过 npm config set cache "url" 来设置缓存路径

设置完成之后就可以通过 npm root -g 来查看第三方模块全局安装的路径了

使用npm管理工程

当要创建一个中小型项目时,通常会在工程目录下使用 npm init ,这个命令就是初始化node工程的命令,运行完之后,会让你输入一些配置信息,如果没有特别配置,一路回车即可。

运行完之后,会在目录下生成一个 package.json 文件,这个文件主要是用来记录这个项目的详细信息的,它会将我们在项目开发中所要用到的包,以及项目的详细信息等记录在这个项目中。方便在以后的版本迭代和项目移植的时候会更加的方便。

在package.json中我们可以看到如下信息

如项目名称、项目描述、作者等等

当我们下载依赖后,会自动生成 node_models 文件夹,这就是npm存放模块的地方

同时也会在 package.json 中生成对应的第三方模块信息,我们也可以手动删除/修改三方包配置信息

每当我们运行 npm install 时,node会自动在当前目录下找到 package.json这个文件,然后根据文件中的配置信息下载或修改第三方库

至此,npm初始化工程就完成了

npm 安装/卸载三方库

  1. npm install xxx 也被简写成 npm i xxx 这是最常见的下载方式,它会把包安装到当前目录下的node_modelus中
  2. npm install xxx@1.x.x 可以精确安装到某个版本
  3. npm install --save xxx 也被简写成 npm install -s xxx 这种方法会将下载的模块信息写入到 package.json 中的dependencies列表中
  4. npm install --save-dev xxx 也被简写成 npn install -D xxx 这种方法会将下载的模块信息写入到 package.json 中的devDependencies列表中
    与第二种方法相比dependencies 是运行时的依赖,而devDependencies是开发时的依赖。也就是说,采用 –save-dev 安装的包我们发布后是用不到的,只有在开发时用到
  5. npm install -g xxx 会将模块安装到全局,也就是上文配置的全局路径下
  6. 使用 npm uninstall xxxnpm uninstall -g xxx 可卸载模块,如全部卸载则使用 npm uninstall -all

cnpm

当使用npm时,有时会遇到下载速度慢或者下载失败的问题,这是因为默认的仓库地址是国外地址,因为某些原因有时候会访问失败,换成国内的镜像即可
执行
npm install -g cnpm --registry=https:registry.npm.taobao.org
cnpm -v
至此,当npm下载模块出错时,可以尝试使用国内镜像的cnpm进行下载

完结

npm作为前端一个强大的包管理器,在某些方面,它甚至能与maven相提并论,用户不仅可以使用npm下载模块,也可以使用npm分享代码,掌握npm已经成了前端的标配