npm 包管理器

他们的共同目标

安装、管理、解决的安装包依赖

基于node的npm

他是node包管理和分发工具
由于npm的软件源地址在国外,所以会出现速度慢很多包安装不上时候:

解决方案一:通过config命令:先运行以下命令,再安装node包

npm config set registry http://registry.cnpmjs.org
npm install webpack

通过上面的命令实际的意识是告诉npm你下载包的时候给我从这个地址下载

解决方案二 cnpm

//cnpm方式安装:先安装cnpm,再利用cnpm安装,例如webpack等
npm install -g cnpm
cnpm install -g webpack

npm install 本地安装和全局安装理解

一、全局安装:
1、提高程序重复利用,避免一个程序多个版本的情况;但是缺点是难以处理不同版本的依赖。

  • 将安装包放在/usr/local下

  • 可以直接在命令行中直接使用

//全局安装
npm install -g webpack
//安装全局的karma
npm install -g karma
//全局安装之后记得在本地安装下并添加进版本依赖中
npm install katma --save-dev
//全局安装完成之后就可以在命令行中直接执行
karma init                

2、
二、本地安装:
1、npm命令默认情况下会将包安装到当前目录下,避免了不同程序依赖不同版本包的冲突;减少了包开发者API的兼容性的问题;缺点是会出现一个包安装多次的情况。

  • 将安装包放在./node_modules/

  • 可以通过require()来引入本地安装的包

//安装在本地
npm install webpack 
//安装在本地并添加进package.json版本依赖中
npm install webpack --save-dev

*–save-dev:把你的安装包信息写入package.json文件的devDependencies字段中,包安装在指定项目的node_modules文件夹下。

注意:
为什么全局安装后还要本地安装

1.在js实例代码中,默认下node.js会在NODE_PATH和目前js所在项目下的node_modules文件夹下去寻找模块,因此,如果只是全局安装,不能直接通过require()的方式去引用模块,需要手动解决包路径的配置问题,当然你也可以复制全局安装的node_modules文件夹到项目下,还有办法可以选择将环境变量的NODE_PATH设置为C:\Program Files\nodejs。

2.对于包的更新不好管理,可能你需要为每个包重新命名,如gulp@3.8.1、gulp@3.9.1…,为了区别不同项目使用指定的包,保证模块之间的相互依赖(这块下面会介绍),区别每个项目正常运行。

使用npm脚本

1、npm 允许在package.json文件里面,使用scripts字段定义脚本命令。

"scripts": {
    "start": "node server.js",
    "karma":"karma start"
}

2、执行的时候npm run karma
这些定义在package.json里面的脚本,就称为 npm 脚本。
npm run在执行的时候会将当前目录的node_modules/.bin子目录加入PATH变量,执行结束后,再将PATH变量恢复原样。

npm脚本的钩子

1、npm 脚本有pre和post两个钩子,比如:

"scripts": {
    "pretest":"karma start",
    "test":"karma start",
    "posttest":"opener http://localhost:9090"
}

当执行npm run test的时候它们会一次执行

npm run pretest && npm run test && posttest

基于淘宝的cnpm(是npm在国内的镜像)

1、抛开package.json的版本依赖先不说,这两种安装方式只不过是安装的位置不同而已。

//上面说了全局安装的是/usr/local/其实全局安装只不过是给你添加了一个环境变而已
//karma="/usr/loacl/bin/node_modules/karma/bin/karma"

karma init --> /usr/loacl/bin/node_modules/karma/bin/karma init

//翻译下本地安装,就是安装在你的当前项目中的node_modules
./node_modules/karma/bin/karma init

基于FaceBook的yarn

特点:
1、极速,Yarn 会缓存它下载的每个包,所以不需要重复下载 ,缓存加并行下载保证了安装速度
2、安全,Yarn 引入 yarn.lock 文件来管理依赖版本问题,在每个安装包的代码执行前使用校验码验证包的完整性,保证每次安装都是一致的。
3、具体的使用请到Yarn官网查看阅读

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值