๐ฆ Understanding Semantic Versioning in package.json
If youโve worked with npm or any JavaScript project, youโve seen version numbers like ^1.2.3 or ~4.5.6 in your package.json. Hereโs a quick breakdown of what they mean and why they matter.
๐ฏ The Format: MAJOR.MINOR.PATCH
Semantic Versioning (SemVer) uses three numbers:
- MAJOR: Breaking changes
- MINOR: New features, backward-compatible
- PATCH: Bug fixes, backward-compatible
Example:
2.3.4 โ MAJOR: 2, MINOR: 3, PATCH: 4
๐ Prefixes and What They Do
In package.json, we often prefix versions to allow for updates:
- 
^(Caret): Updates to the latest minor and patch version.
 Example:^1.2.3allows anything from1.2.3to<2.0.0.
- 
~(Tilde): Updates only to the latest patch version.
 Example:~1.2.3allows anything from1.2.3to<1.3.0.
- 
No Prefix: Locks the version. 
 Example:1.2.3means only use that version.
- 
*(Wildcard): Allows any version. Use with caution.
โ When to Use What
- Use ^for libraries you trust to follow SemVer properly.
- Use ~when you want more stability (e.g., for shared tools).
- Avoid *or unpinned versions in production.
- Use exact versions when debugging or building reproducible environments.
๐ Pro Tip: Lock it Down
Even with flexible ranges, always check in a package-lock.json or pnpm-lock.yaml to pin exact resolved versions for your builds.
Want to go deeper? semver.org has the full spec.
