前端开发的时候常常用到npm安装依赖包,初步使用的时候会跟着使用不少命令--save -dev之类的,看起来没有太大的区别,那为何要这么用呢?就要深刻了解一下package.json文件。css
不少时候咱们都是站在别人的肩膀上写代码,会引入不少依赖包,那天然,就须要对这些包的安装卸载有一个统一的管理。
建立package.json文件是用来管理npm依赖包的最好方式。html
那就很明确,package.json只是一个记录文件,npm借由这个记录文件对依赖包进行管理。前端
那首先一开始,咱们须要生成package.json文件node
npm init
npm init --yes
express
生成文件有两个命令,前者是手动命令,输入后,咱们能够手动配置项目的一些信息,不输入直接回车,就会自动填充默认配置。npm
后者是快捷命令。顾名思义,快捷命令就是按照默认设置,直接生成文件,文件内容以下:json
{ "name": "test", "version": "1.0.0", "description": "", "main": "index.js", "scripts": { "test": "echo \"Error: no test specified\" && exit 1" }, "keywords": [], "author": "", "license": "ISC" }
根据文件咱们能够看到一些基本的内容,分别的意思是:gulp
name:当前目录名称
version:永远是 1.0.0
description:来自自述文件的信息或空字符串 ""
main:永远是 index.js
scripts:默认状况下会建立一个空test脚本
keywords:空的
author:空的
license: ISC
bugs:来自当前目录的信息(若是存在)
homepage:来自当前目录的信息(若是存在)
对于package.json来讲,name与version是必须的,也有必定的要求。测试
"name"spa
- 全是小写的
- 一个词,没有空格
- 容许破折号和下划线
"version"
- 以x.x.x的形式
- 遵循semver规范
也可使用初始命令配置一些选项
npm set init.author.email "wombat@npmjs.com"
npm set init.author.name "ag_dubs"
npm set init.license "MIT"
若是文件中中没有描述字段,package.json就会使用README.md或README 的第一行。该描述可帮助人们在搜索npm时找到您的包,所以在package.json中写入自定义描述,可让人更容易找到包。
总的来讲:
package.json文件
除了上面介绍的基本信息以外,就是咱们的核心信息——项目中所使用的全部依赖包。
仔细发现的话,咱们会在package.json文件中找到两种类型的依赖包列表:
"dependencies":项目在生产环境中须要的包。
"devDependencies":开发和测试中须要的包。
例如,下面的项目使用my_dep与生产中的主要版本1匹配的任何版本的软件包,而且须要my_test_framework与主要版本3匹配的任何版本的软件包,但仅用于开发:
{ "name": "my_package", "version": "1.0.0", "dependencies": { "my_dep": "^1.0.0" }, "devDependencies" : { "my_test_framework": "^3.1.0" } }
那如何控制安装依赖包分别到两个列表里呢?这就是npm install的后缀用途
向项目中安装package.json中的依赖包的更简单(也更棒的)方法,是从命令行npm install执行此操做,使用--save或 标记命令--save-dev,具体取决于但愿如何使用该依赖项。
一个条目添加到您package.json的dependencies:
npm install <package_name> --save
一个条目添加到您package.json的devDependencies:
npm install <package_name> --save-dev
咱们在使用 npm install 安装模块的模块的时候 ,通常会使用下面这几种命令形式:
npm install moduleName
安装模块到项目目录下
npm install -g moduleName
-g 的意思是将模块安装到全局,具体安装到磁盘哪一个位置,要看 npm config prefix 的位置。
npm install -save moduleName
-save 的意思是将模块安装到项目目录下,并在package文件的dependencies节点写入依赖。
npm install -save-dev moduleName
-save-dev 的意思是将模块安装到项目目录下,并在package文件的devDependencies节点写入依赖。
那么问题来了,在项目中咱们应该使用四个命令中的哪一个呢?这个就要视状况而定了。下面对这四个命令进行对比,看完后你就再也不这么问了。
npm install moduleName 命令
npm install -g moduleName 命令
npm install -save moduleName 命令
npm install -save-dev moduleName 命令
总结
devDependencies 节点下的模块是咱们在开发时须要用的,好比项目中使用的 gulp ,压缩css、js的模块。这些模块在咱们的项目部署后是不须要的,因此咱们可使用 -save-dev 的形式安装。像 express 这些模块是项目运行必备的,应该安装在 dependencies 节点下,因此咱们应该使用 -save 的形式安装。
npm使用语义版本控制,或者,正如咱们常常提到的那样,SemVer,用于管理软件包版本和范围。
若是你的package.json目录中有一个文件而且你运行npm install,npm将查看该文件中列出的依赖项并使用语义版本控制下载最新版本