Understanding and Resolving npm ERESOLVE Dependency Conflicts

Resolve npm ERESOLVE peer dependency conflicts the right way: identify the real mismatch, align versions, use overrides safely, and know when pnpm or Yarn is a better fit.
Publié:
Aleksandar Stajić
Updated: 16 mars 2026 à 09:12
Understanding and Resolving npm ERESOLVE Dependency Conflicts

Illustration

Understanding and Resolving npm ERESOLVE Dependency Conflicts

An npm ERESOLVE error means npm couldn't build a dependency tree that satisfies all version rules — most often because of peer dependencies. Since npm 7, peer dependencies are handled strictly during install, so conflicts that previously installed “anyway” now fail fast.

That strictness reduces runtime surprises, but it can block installs when one package expects older versions than your project.

Quick Triage: Find the Actual Conflict

Before you force anything, identify who requires what. These commands usually pinpoint the culprit in under a minute.

npm -v
node -v

# show dependency chain
npm ls @tensorflow/tfjs
npm ls react

# show peer dependency requirements
npm view @tensorflow-models/handpose peerDependencies

# explain why a version was chosen
npm explain @tensorflow/tfjs

Why Peer Dependency Conflicts Happen

Peer dependencies are compatibility contracts. A library says: “I don't ship React / TFJS myself — you must provide a compatible version.” Conflicts happen when two packages demand incompatible version ranges.

  • Package A requires @tensorflow/tfjs ^3, but your project installs @tensorflow/tfjs@4.
  • A plugin requires react@^17, while your app is on react@18.
  • You mixed majors in a package family (e.g. tfjs core v4, backends still v3).

How to Fix npm ERESOLVE (Safest → Most Aggressive)

1) Align Versions (Best Long-Term Fix)

Keep one compatible major across the entire dependency family. This is the fix that survives CI, deployments, and future upgrades.

// package.json (example: align tfjs family on v3)
{
  "dependencies": {
    "@tensorflow/tfjs": "^3.21.0",
    "@tensorflow/tfjs-backend-webgl": "^3.21.0",
    "@tensorflow/tfjs-backend-cpu": "^3.21.0",
    "@tensorflow-models/handpose": "^0.0.7"
  }
}
rm -rf node_modules package-lock.json
npm install

2) Use npm "overrides" (Controlled Forcing, npm 8+)

Use overrides when a transitive dependency pulls the wrong version. This is safer than --force, but you must test runtime behavior.

// package.json
{
  "overrides": {
    "@tensorflow/tfjs": "^4.0.0",
    "@tensorflow/tfjs-backend-webgl": "^4.0.0",
    "@tensorflow/tfjs-backend-cpu": "^4.0.0"
  }
}
rm -rf node_modules package-lock.json
npm install

3) --legacy-peer-deps (Fast Unblock, Less Safety)

Bypasses strict peer resolution and installs anyway. Good for quick experiments — risky as a default in production.

npm install --legacy-peer-deps

4) --force (Last Resort)

Forces an install even when npm knows the tree is inconsistent. Use only if you accept potential runtime breaks.

npm install --force

5) Clean Install Checklist (Fixes Weird Lockfile States)

rm -rf node_modules package-lock.json
npm cache verify
npm install

npm vs pnpm vs Yarn: Practical Differences

All three can hit peer conflicts, but they differ in speed, node_modules strategy, and how quickly they expose "hidden" dependency mistakes.

npm (v7+): strict by default

  • Pros: catches incompatible peer combos early; predictable CI.
  • Cons: blocks installs more often; people reach for flags.
  • Best for: teams that want strict correctness over convenience.

pnpm: fast, disk-efficient, stricter dependency access

pnpm uses a global content-addressable store and links packages. Installs are typically faster and use less disk. Its stricter layout can reveal missing direct dependencies earlier.

corepack enable
corepack prepare pnpm@latest --activate

pnpm install

Yarn: strong workspaces tooling, flexible resolutions

Yarn is popular in monorepos. Depending on Yarn version/config it can feel more forgiving, but the big win is workspaces and its ability to pin versions via resolutions.

corepack enable
corepack prepare yarn@stable --activate

yarn install

# package.json (Yarn) -> "resolutions": { "react": "18.2.0" }

Conclusion

For production: prefer aligning versions or controlled overrides. Use --legacy-peer-deps to unblock quickly, and reserve --force for last resort. If installs are slow or the repo is large, pnpm is often a strong upgrade. If workspaces and strict pinning matter, Yarn is a good fit.

Copy/Paste Snippets

# safest: align versions
rm -rf node_modules package-lock.json
npm install

# controlled: overrides
# package.json -> "overrides": { "pkg": "version" }

# quick unblock
npm install --legacy-peer-deps

# last resort
npm install --force

Related Articles

tensorflow

tensorflow

Enterprise-Grade Multi-Tenant Architecture for an International Platform

Enterprise-Grade Multi-Tenant Architecture for an International Platform

Loving Rocks is an enterprise-grade wedding platform designed with a true multi-tenant architecture, isolated databases per tenant, and built-in internationalization for global scalability, security, and long-term operational stability.

konvertieren-rpm-in-debian-ubuntu-deb-format-debian-package-manager

apache-ubuntu-17-10-install-certbot-lets-encrypt

Guide complet de Test DEv Enterprise Stajic.de : architecture et bonnes pratiques

Guide complet de Test DEv Enterprise Stajic.de : architecture et bonnes pratiques

Explorez les principes architecturaux, les avantages et les détails techniques de la gestion d'un environnement de développement et de test de niveau entreprise avec Test DEv Enterprise Stajic.de.

Architecture Canonique, Conception d'URL, Logique de Résolution, Spécification d'API et d'Évolutivité

Architecture Canonique, Conception d'URL, Logique de Résolution, Spécification d'API et d'Évolutivité

Architecture de découverte géolocalisée pour les portails multi-locataires. Définit les URL canoniques, la logique de résolution, la stratégie de mise en cache et un modèle de lecture géo sans couplage CMS ni refactorisation de base de données. Conçue pour la stabilité SEO, l'évolutivité et les futures extensions comme la réservation et les cartes.

Google I/O 2026 : Antigravity, AI Studio et la transition vers les DevTools agentiels

Google I/O 2026 : Antigravity, AI Studio et la transition vers les DevTools agentiels

Google I/O 2026 a rendu une chose claire pour les ingénieurs : les outils d'IA vont désormais au-delà de l'autocomplétion pour passer à une exécution agentique gérée. Cet article décrypte Antigravity 2.0, le rôle croissant de Google AI Studio, Gemini 3.5 Flash et les véritables compromis autour de l'orchestration, du verrouillage, de la vérification et de la conception des workflows de développement.

Maîtriser la ligne de commande : un guide complet sur la commande find

Libérez tout le potentiel de la commande Linux find. Ce guide couvre la syntaxe, des exemples détaillés et des détails techniques pour une gestion efficace des fichiers.

Développement de portail : Une plateforme évolutive pour la performance, le support multilingue et l'extensibilité

Développement de portail : Une plateforme évolutive pour la performance, le support multilingue et l'extensibilité

Un portail web moderne est en développement. Il privilégie performance, évolutivité, support

install-pcl-library-on-python-ubuntu-19-10-point-cloud-librar

Paquets Snap : Pourquoi ils ne sont pas à la hauteur pour les outils avancés comme DBeaver

Paquets Snap : Pourquoi ils ne sont pas à la hauteur pour les outils avancés comme DBeaver

Les paquets Snap introduisent un bac à sable restrictif qui perturbe les flux de travail avancés. Cet article explique pourquoi DBeaver rencontre des difficultés avec le tunneling SSH sous Snap et pourquoi les paquets Flatpak ou natifs sont de meilleures alternatives.

Conversion HEIC en JPG : Pourquoi vous devriez l'envisager et comment cela fonctionne

Conversion HEIC en JPG : Pourquoi vous devriez l'envisager et comment cela fonctionne

Le HEIC offre une compression d'image moderne et une haute qualité, mais le JPG reste le format le plus compatible. Ce guide explique quand et comment convertir le HEIC en JPG à l'aide d'outils Linux et de l'automatisation.