Avoid installing different versions from the same module
By Mario Kandut
This tutorial explains what the difference between
package-lock.json is, and why
package-lock.json can help to avoid installing modules with different versions.
If you are not sure what the
package.json is responsible for, check out this article - The basics of Package.json.
package-lock.json is a file generated by npm (since v5 2017), and it locks package dependencies and their sub-dependencies.
It tracks only top-level dependencies, and their associated versions. Sounds simple right? Though each of these top-level dependencies can also have their own dependencies, and each of these can also have their own dependencies and so on.
This relationship between all the dependencies and sub-dependencies in a project is called the dependency tree.
The dependency tree represents every module our project depends on and what version is required.
💰 Start your cloud journey with $100 in free credits with DigitalOcean.
Installing a dependency with npm actually fetches all the needed dependencies, and installs them into the
package-lock.json file is a snapshot of our entire dependency tree and all the information npm needs to recreate the state of the
Also, when a
package-lock.json file is present,
npm install will install the exact versions specified.
package-lock.json is not meant to be human-readable, and it's not meant to be edited manually.
The npm CLI generates and manages it for us automatically.
package-lock.json file needs to be committed to version control (GIT) to make sure the same dependency tree is used every time.
The benefit of committing the package-lock file to version control is tracking the state of the node_modules/ folder
without having to commit the folder itself to version control. Never commit the node-modules folder.
It is not intended to be committed, it's too big, and the state is already tracked.
Whenever we run a npm command that changes dependencies, like
npm install <PACKAGE> or
npm uninstall <PACKAGE> or
npm update or any other command that alters dependencies,
package-lock.json file will be updated to reflect the state of the dependency tree.
Locking dependencies is not a new concept in the Node.js ecosystem or in the programming world. The
package-lock file behaves nearly like the already existing
npm-shrinkwrap.json, which was how to lock a package before npm v5.
The only difference is that the
package-lock.json is ignored by npm when publishing to the NPM registry. If you want to lock your dependencies, when publishing a package you have to use
You should only have one of these files in your root directory. If both are present
npm-shrinkwrap takes precedent.
The recommended use-case for
npm-shrinkwrap.json is applications deployed through the publishing process on the NPM registry.
To create a npm-shrinkwrap file, run
npm shrinkwrap. This command renames your
npm-shrinkwrap. The files are functionally the same.
npm-shrinkwrap should be used when publishing to the NPM registry.
package-lock.jsonis a snapshot of the entire dependency tree (all packages, all dependencies. all resolved version numbers)
package-lock.jsonis updated automatically on dependency changes.
Thanks for reading and if you have any questions, use the comment function or send me a message @mariokandut.
3 min read
Get the latest bug fixes and performance improvements.
3 min read
Bundle shell commands and automate repetitive tasks.
2 min read
Uninstall packages completely from a project - manually or automatically