npm详解

1、npm介绍及安装node

对于npm,你们多多少少都用过,做为一门技术,我想写篇博客记录一下,一块儿分享,一块儿学习。jquery

npm,是Node Package Manager的缩写,node的模块管理器,它是随同NodeJS一块儿安装的包管理和分发工具。经过npm能够实现JavaScript资源的下载、共享、发布,npm汇集了丰富大量的JavaScript资源包。若是你有GitHub的使用经验,其实npm的性质跟github有点相似,npm是JavaScript的资源管理平台,只不过npm有本身的发布和下载规范。git

对于npm的安装,其实新版本的nodeJS已经集成了npm,因此只要你安装了nodejs,其也一并装好了。github

 2、如何使用淘宝镜像express

像介绍所说的,npm拥有大量JavaScript资源包,而资源包服务器是在国外的,经过命令下载资源包的时候,因地域网速而异,国内相对会比较慢,在这里,我介绍一下使用淘宝镜像加载npm中的JavaScript资源包。你也能够访问https://npm.taobao.org/自行操做。npm

打开命令行,输入指令:npm install -g cnpm --registry=https://registry.npm.taobao.org,回车便可,待加载完:json

因为是全局安装,保存目录在全局中,以下:服务器

 

那就成功了。以后使用cnpm代替npm就能够了。svn

好比:npm install 用 cnpm install 代替。工具

3、初始化package.json

package.json 位于项目的根目录下面,用于定义包的属性,记录全部安装模块的名字。package.json有项目开发及发布中全部的依赖包,在团队开发中,只须要把package.json文件共享,其它开发者只须要经过 npm install 命令安装package.json文件中记录的资源就能够了,无需把全部的资源包发送给其余开发者。下面咱们来看一下如何初始化package.json。

一、在项目根目录打开命令行窗口,能够按shift键,点鼠标右键,选择在此处打开窗口命令,或者cd 到当前项目目录

二、输入 npm init 回车

三、按照项目填写相关信息,具体属性参数以下:

name - 包名。

version - 包的版本号。

description - 包的描述。

homepage - 包的官网 url 。

author - 包的做者姓名。

contributors - 包的其余贡献者姓名。

dependencies - 依赖包列表。若是依赖包没有安装,npm会自动将依赖包安装在node_module 目录下。

repository - 包代码存放的地方的类型,能够是git 或 svn,git 可在 Github 上。

main - main 字段是一个模块ID,它是一个指向你程序的主要项目。

keywords - 关键字

最后点击yes就能够生成package.json文件。

这里我就随便敲了,格式以下:

{
  "name": "npm",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}

 

4、npm安装模块

安装指令以下:npm install <Module Name>@<?>

<Module Name>是资源模块名称,例如:jquery,@<?>是版本号,能够省略,也能够指定版本号,省略默认最新版本。

安装分全局安装和本地安装,指令区别是全局多了个'-g',如 npm install jquery -g 或npm install -g jquery

二者仍是有区别的:

一、安装位置会不同。全局安装会安装到全局环境里面,路径能够经过指令npm root -g查到,通常在 \Users\用户名\AppData\Roaming\npm\node_modules目录下。

本地安装就直接在项目路劲的node_modules下。

二、调用方式不同

全局安装会生成cmd文件,供命令行使用。

本地安装能够直接经过require()的方式引入项目中node_modules目录下的模块

var jq = require('jquery');
document.write('<h1>Hello World!!!</h1>');
alert(jq('h1').length);

npm还提供了开发依赖安装(devDependencies)与生产依赖安装(dependencies),安装指令稍微有些不同,举个安装jquery的例子:

生产依赖:npm install jquery --save 或 npm install --save jquery 

开发依赖:npm install jquery --save-dev 或 npm install --save-dev jquery

使用--save 和--save-dev标识符,还会在package.json文件的dependencies字段和devDependencies字段添加该package的名称和版本号:

(提示:一、此处可使用淘宝镜像下载,好比cnpm install jquery --save-dev,会提升加载速度;二、版本号前面的'^'表示版本向上取最新的,好比说若是JQ出了个4版本,就会去到4版本)

5、整理npm常见的指令

除了上述所讲的指令,npm还有不少指令,下面整理列出:

一、版本检查:npm -v

二、安装指令:npm install [-S|--save|-D|--save-dev|-O|--save-optional] [-E|--save-exact] [--dry-run]

三、卸载指令:npm uninstall jquery --save 或者 npm uninstall jquery(加 --save 会自动把package.json中dependencies属性中的jquery删除,不加则不删除)

四、更新指令:npm update jquery

五、搜索指令:npm search express

六、帮助指令:npm help

七、查看模块:npm ls(全局npm ls -g)

八、查看包的安装路径:npm root [-g]

九、管理npm配置:npm config

npm config set <key> <value> [-g|--global]
npm config get <key>
npm config delete <key>
npm config list
npm config edit
npm get <key>
npm set <key> <value> [-g|--global]

 

十、更新npm:npm install npm -g

十一、注册用户:npm adduser

十二、发布模块:npm publish

还有更多的指令待你们探索,分享就到这里,欢迎转载,请注明出处!

相关文章
相关标签/搜索