package.json和npm

Posted So istes immer

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了package.json和npm相关的知识,希望对你有一定的参考价值。

目录

1.package.json

建议每一个项目都要有一个package.json,这个文件就像产品的说明书一样,记录了项目的信息

该文件可以用npm init来初始化创建 

 按照上面这种方式创建的package.json是这样子的

{
  "name": "test",
  "version": "1.0.0",
  "description": "这是一个测试文件",
  "main": "main.js",
  "scripts": {
    "test": "echo \\"Error: no test specified\\" && exit 1"
  },
  "author": "fyx",
  "license": "ISC"
}

我们来安装一个包 npm i art-template --save,再看看package.json

{
  "name": "test",
  "version": "1.0.0",
  "description": "这是一个测试文件",
  "main": "main.js",
  "scripts": {
    "test": "echo \\"Error: no test specified\\" && exit 1"
  },
  "author": "fyx",
  "license": "ISC",
  "dependencies": {
    "art-template": "^4.13.2"
  }
}

我们发现在dependencies这个选项中就记录了第三方包的名称

向上标号^是定义了向后(新)兼容依赖,指如果art-template的版本是超过4.13.2,并在大版本号(4)上相同,就允许下载最新版本的 art-template库包,例如实际上运行npm install时候下载的具体版本可能是4.13.10。

执行这个命令的时候,在项目根目录下会新增一个node_modules文件夹,你会发现这里面有很多包,这是因为art-template包本身依赖了很多其它包,同样,这些包也可能依赖了其它包。

但是,package.json只会记录最上层的art-template。

执行这个命令还会生成一个package-lock.json文件,它的作用是锁定安装时的包的版本号,因为package.json文件只能锁定大版本,也就是版本号的第一位,并不能锁定后面的小版本。从而保证在不同时间或者不同npm下载源之下,用户下载到的依赖包的版本都一样。

我们执行npm i jquery --save-dev,再看看package.json 

{
  "name": "test",
  "version": "1.0.0",
  "description": "这是一个测试文件",
  "main": "main.js",
  "scripts": {
    "test": "echo \\"Error: no test specified\\" && exit 1"
  },
  "author": "fyx",
  "license": "ISC",
  "dependencies": {
    "art-template": "^4.13.2"
  },
  "devDependencies": {
    "jquery": "^3.6.0"
  }
}

发现,和前面略有不同,这是因为--save-dev安装的是开发和测试中需要用到的包,--save安装的是运行项目所要用到的包。

如果你不小心删除了node_modules文件夹,只要还有package.json这个文件夹,你就可以依据npm install这个命令把要依赖的包安装回来。

2.npm

npm全称node package manager,是一个包管理工具

npm官网能搜索到的包,都可以用npm指令下载

安装了node会自动安装npm

查看npm版本:npm --version
升级npm版本:npm install --global npm 

npm常用指令

npm init
npm init -y  可以跳过向导,快速生成
npm install以一次性把dependencies选项中的依赖项全部安装,简写:npm i
npm insatll 包名,简写:npm i
npm install --save,简写:npm i -S
npm uninstall 包名,简写:npm un 包名(只删除包,package.json中依然保留信息)
npm uninstall --save 包名,
简写:npm un -S 包名(删除包的同时会把依赖信息也删掉)
npm help,查看使用帮助
npm 命令 --help,查看指定命令的使用帮助,比如去查uninstall的简写:npm uninstall --help

npm存储包文件的服务器再国外,有时候速度很慢,如何解决?

https://npmmirror.com/ 淘宝的开发团队把npm在国外做了一个备份
安装淘宝的cnpm: npm install --global cnpm (global表示安装到全局)
使用npm安装走的是国外的npm服务器,使用cnpm走的是淘宝的服务器
以后安装包就可以用cnpm

如果不想安装cnpm又想使用淘宝的服务器来下载
npm install jquery --registry=http://registry.npm.taobao.org
但是每一次手动这样加参数很麻烦,所以我们可以把这个选项加入到配置文件中:
npm config set registry http://registry.npm.taobao.org
查看npm配置信息:npm config list
这样配置以后,以后用npm install下载会默认走淘宝的服务器

以上是关于package.json和npm的主要内容,如果未能解决你的问题,请参考以下文章

NodeJs开发之三: package.json和Package_lock.json

npm中package.json详解

npm脚本和package.json

npm-shrinkwrap.json 和 package-lock.json 有啥区别?

与 npm 和 yarn 一起使用的 package.json 脚本?

检查 NPM package.json 和 package-lock.json 是不是兼容