根据官方文档,这个package-lock.json 是在 `npm install`时候生成一份文件,用以记录当前状态下实际安装的各个npm package的具体来源和版本号。

它有什么用呢?因为npm是一个用于管理package之间依赖关系的管理器,它允许开发者在pacakge.json中间标出自己项目对npm各库包的依赖。你可以选择以如下方式来标明自己所需要库包的版本

这里举个例子:

"dependencies": {
"@types/node": "^8.0.33",
},

这里面的 向上标号^是定义了向后(新)兼容依赖,指如果 types/node的版本是超过8.0.33,并在大版本号(8)上相同,就允许下载最新版本的 types/node库包,例如实际上可能运行npm install时候下载的具体版本是8.0.35。波浪号

大多数情况这种向新兼容依赖下载最新库包的时候都没有问题,可是因为npm是开源世界,各库包的版本语义可能并不相同,有的库包开发者并不遵守严格这一原则:相同大版本号的同一个库包,其接口符合兼容要求。这时候用户就很头疼了:在完全相同的一个nodejs的代码库,在不同时间或者不同npm下载源之下,下到的各依赖库包版本可能有所不同,因此其依赖库包行为特征也不同有时候甚至完全不兼容。

因此npm最新的版本就开始提供自动生成package-lock.json功能,为的是让开发者知道只要你保存了源文件,到一个新的机器上、或者新的下载源,只要按照这个package-lock.json所标示的具体版本下载依赖库包,就能确保所有库包与你上次安装的完全一样。

package.json 这个文件是 npm init 时创建的一个文件,会记录当前整个项目中的一些基础信息。而 package-lock.json 这个文件却是 node_modules 文件夹或者 package.json 文件发生变化时自动生成的。这个文件主要功能是确定当前安装的包的依赖,以便后续重新安装的时候生成相同的依赖,而忽略项目开发过程中有些依赖已经发生的更新。

  自npm 5.0版本发布以来,npm i的规则发生了三次变化。

  1、npm 5.0.x 版本,不管package.json怎么变,npm i 时都会根据lock文件下载
    package-lock.json file not updated after package.json file is changed · Issue #16866 · npm/npm    这个 issue 控诉了这个问题,明明手动改了package.json,为啥不给我升级包!然后就导致了5.1.0的问题...

  2、5.1.0版本后 npm install 会无视lock文件 去下载最新的npm
    why is package-lock being ignored? · Issue #17979 · npm/npm    这个issue控诉这个问题,最后演变成5.4.2版本后的规则。

  3、5.4.2版本后 why is package-lock being ignored? · Issue #17979 · npm/npm    大致意思是,如果改了package.json,且package.json和lock文件不同,那么执行`npm i`时npm会根据package中的版本号以及语义含义去下载最新的包,并更新至lock。

  如果两者是同一状态,那么执行`npm i `都会根据lock下载,不会理会package实际包的版本是否有新。

package.json 这个文件是 npm init 时创建的一个文件,会记录当前整个项目中的一些基础信息。而 package-lock.json 这个文件却是 node_modules 文件夹或者 package.json 文件发生变化时自动生成的。这个文件主要功能是确定当前安装的包的依赖,以便后续重新安装的时候生成相同的依赖,而忽略项目开发过程中有些依赖已经发生的更新。

  自npm 5.0版本发布以来,npm i的规则发生了三次变化。

  1、npm 5.0.x 版本,不管package.json怎么变,npm i 时都会根据lock文件下载
    package-lock.json file not updated after package.json file is changed · Issue #16866 · npm/npm    这个 issue 控诉了这个问题,明明手动改了package.json,为啥不给我升级包!然后就导致了5.1.0的问题...

  2、5.1.0版本后 npm install 会无视lock文件 去下载最新的npm
    why is package-lock being ignored? · Issue #17979 · npm/npm    这个issue控诉这个问题,最后演变成5.4.2版本后的规则。

  3、5.4.2版本后 why is package-lock being ignored? · Issue #17979 · npm/npm    大致意思是,如果改了package.json,且package.json和lock文件不同,那么执行`npm i`时npm会根据package中的版本号以及语义含义去下载最新的包,并更新至lock。

  如果两者是同一状态,那么执行`npm i `都会根据lock下载,不会理会package实际包的版本是否有新。

最新文章

  1. TThread.CreateAnonymousThread() 匿名线程对象的应用
  2. java 平面上最近两个点之间的距离
  3. Python描述符(descriptor)解密(转)
  4. Scalaz(12)- Monad:再述述flatMap,顺便了解MonadPlus
  5. SQLServer(MSSQL)、MySQL、SQLite、Access相互迁移转换工具 DB2DB v1.1
  6. YAFFS2文件系统分析(转)
  7. 多一个“点”给IIS与ASP.NET带来的问题
  8. 更新的packages.config所有的软件包?
  9. yii2源码学习笔记(二十)
  10. vc6静态库的生成和调用
  11. v8 源码获取与build
  12. if switch练习(体重)
  13. 【Java数据结构】Java数据结构之链表反转
  14. android 定时器(Handler Timer Thread AlarmManager CountDownTimer)
  15. Sql 查询当天、本周、本月记录、上周、上月记录
  16. 挑战常规--为什么不应该使用Jsonp进行跨域
  17. 【BZOJ4712】洪水
  18. 【Codeforces 1120C】Compress String
  19. spring data redis使用1——连接的创建
  20. java---简单的ATM存取系统,

热门文章

  1. S04_CH02_工程移植ubuntu并一键制作启动盘
  2. Linux 内核错误码
  3. Python中的单例模式的几种实现方式和优化以及pyc文件解释(转)
  4. nginx 禁止浏览器缓存
  5. JQuery 的优先级
  6. python的excel处理之openpyxl
  7. requests模块的基本用法
  8. 云端的ABAP Restful服务开发
  9. Robo 3T SQL
  10. Dism++备份还原系统