migrate
Lodash Migration & Compat Guide
Guide users through migrating lodash to es-toolkit and understanding the strict vs compat APIs, grounded in actual source code.
Input
$ARGUMENTS — Lodash code to migrate, specific function names, or a question about strict vs compat.
Core Concepts
es-toolkit (strict): Opinionated, simplified API for the 85% use case. Smaller bundle, may differ from lodash in edge cases by design. New functions are added here.
es-toolkit/compat: Aims for full lodash test compatibility within a defined scope. See docs/compatibility.md for out-of-scope behaviors (e.g., implicit type conversions, prototype modifications).
Why source-first matters
The only reliable way to know the difference between strict and compat is to read the actual implementation. Never guess — always verify from source.
Workflow
If a specific function or lodash code is given
1. Identify lodash functions from input
Extract which lodash functions are used and how they're imported.
2. Verify availability in source code
For each function, search both APIs:
src/{category}/{fn}.ts— strict APIsrc/compat/{category}/{fn}.ts— compat API
Read the implementation to understand the exact signature and any behavioral differences.
3. Determine the right migration path
| Scenario | Recommendation |
|---|---|
| Function exists in both, same behavior | Use es-toolkit (smaller bundle) |
| Function exists in both, different behavior | Explain the difference, let user choose |
| Only in compat | Use es-toolkit/compat |
| Not available at all | Keep lodash or suggest modern JS alternative |
If the function only exists in compat (like get, set, has), explain why — es-toolkit doesn't implement functions replaceable by modern JS (optional chaining ?., Object.hasOwn(), etc.).
4. Generate before/after migration
For each function, provide:
- Availability: es-toolkit and/or es-toolkit/compat
- Doc link:
https://es-toolkit.dev/reference/{category}/{fn}(strict) orhttps://es-toolkit.dev/reference/compat/{category}/{fn}(compat) - Before (lodash) and After (es-toolkit) code examples
- Any behavioral differences found in source code
- Feature comparison table: Compare API capabilities side-by-side (e.g., cancel support, flush, maxWait, return values, AbortSignal, callback arguments). Read both implementations to identify all supported options and present them in a table like:
| Feature | lodash | es-toolkit | es-toolkit/compat |
|---|---|---|---|
| (list each option/capability) | ✅/❌ | ✅/❌ | ✅/❌ |
- "When to use which": Based on the feature comparison, provide scenario-based guidance — e.g., "Use es-toolkit if you only need basic debounce; use compat if you rely on cancel/flush; keep lodash if you need X."
For migrations involving many functions, use a summary table instead of repeating the full template for each one.
5. Provide consolidated import rewrite
Show the final import transformation as a single block.
5a. Suggest automation patterns for large-scale migrations
When migrating many files, mention practical automation approaches:
- Bundler alias: Configure
resolve.aliasin webpack or Vite to redirect lodash imports at build time without changing source files:// vite.config.js or webpack.config.js resolve: { alias: { 'lodash': 'es-toolkit/compat' } } - ESLint rule: Use
no-restricted-importsto warn or error on remaining lodash imports after migration. - Codemod: For systematic AST-based transforms, mention tools like jscodeshift if the migration pattern is complex.
6. Note bundle size impact
es-toolkit is up to 97% smaller than lodash and 2-3x faster. Bundle size numbers come from benchmarks/bundle-size/ and runtime performance numbers from benchmarks/performance/ and docs/performance.md — reference them for specific function comparisons if the user asks.
If no specific function (migration strategy overview)
Provide a strategic overview with three migration options:
- Option A: Direct to es-toolkit — new/small projects
- Option B: Gradual via compat — large codebases (recommended for legacy)
- Option C: Mixed — pragmatic approach
For each option, include a trade-off matrix:
| Factor | Option A (strict) | Option B (compat) | Option C (mixed) |
|---|---|---|---|
| Code change volume | High | Low | Medium |
| Bundle size reduction | Maximum | Moderate | Varies |
| Risk level | Higher (behavior diffs) | Low (lodash-compatible) | Medium |
| Maintenance effort | Low (clean API) | Medium (compat tracking) | Higher (two APIs) |
Compat-exclusive functions: Search src/compat/ for functions that don't exist in src/ (strict). List representative examples so users know what can only come from compat (e.g., get, set, has).
For concrete behavioral differences, read a few representative function pairs from source (e.g., chunk, debounce) to give real examples rather than abstract descriptions.
Search local docs for discovery
If you need to check whether a lodash function has an es-toolkit equivalent:
- By name: Read
docs/reference/{category}/{functionName}.mddirectly - By keyword:
Grepfor the function name acrossdocs/reference/**/*.md - Compat-only functions:
Glob docs/reference/compat/{category}/*.md— then check if the same file exists indocs/reference/{category}/ - Available categories: array, compat, error, function, map, math, object, predicate, promise, set, string, util
More from toss/es-toolkit
recommend
Analyze code or requirements and recommend the best es-toolkit functions. Use when the user asks which es-toolkit function to use, needs help finding a utility, or wants alternatives to manual implementations.
99guide
es-toolkit usage guide covering installation, import patterns, and setup for Node.js, Bun, Deno, and browsers. Use when the user asks how to install, import, or set up es-toolkit in their project.
74compat-review
Verify compat PR claims by running lodash vs es-toolkit/compat at runtime
32pr-review
Review recent PRs with deep context and label-specific checks
27release
Create a new es-toolkit release (version bump, changelog, tag)
26issue-label
Suggest and apply GitHub labels to unlabeled issues
26