- Stable
3.0.0
- Canary
3.0.1-alpha.1
Toggle Menu
Eleventy
1.93s
Next.js
70.65s
Incremental Builds
Incremental builds via the command line flag --incremental
perform a partial build operating only on files that have changed to improve build times when doing local development.
Let’s check in on the current capabilities and the roadmap:
- Templates
- If you create/update a template file, Eleventy will run the build for that file and only that file.
- Layouts Added in v2.0.0
- When you change a layout file, any templates using that layout file are rebuilt.
- Template Dependencies Added in v2.0.0Any templates using a dependency mapped via the
addDependencies
method will be rebuilt when those dependencies change.- This feature was previously exposed as part of the API for Custom template extensions via the
isIncrementalMatch
function. - Other Includes: If the created/updated file is in your Includes or Layouts directories, a full build will run. Added in v2.0.0Files used as Eleventy Layouts in your build are exempted.
- This feature was previously exposed as part of the API for Custom template extensions via the
- Collections Added in v2.0.0
- When you add or delete a tag from a template, any templates using that collection tag (as declared by
pagination.data
oreleventyImport.collections
) will be rebuilt.
- When you add or delete a tag from a template, any templates using that collection tag (as declared by
- Passthrough Copy
- Incremental passthrough copy uses the following rules:
- Only copy a passthrough copy file when it actively changed. Don’t run a template build if only a passthrough copy file has changed.
- If a template has changed, don’t copy the passthrough copy files.
- There was some discussion about making this behavior default at Issue #1109.
- Added in v2.0.0 Passthrough copy can be emulated during
--serve
to speed up both incremental and non-incremental builds.
- Configuration File
- If you create/update your Eleventy configuration file, a full build will run.
- Don’t build on startup: Added in v2.0.0
--ignore-initial
was added and works great with--incremental
.
Additional Template Language Features
The previously stated incremental features are implemented in Eleventy core and are available to all template languages. Some template types offer additional --incremental
build support:
- WebC: deep knowledge of the full component dependency graph allows us to smartly build templates that use a component when that component is changed.
🗓 To Do
- Cold Start Incremental:
--incremental
does a full build to start out to provide a fresh starting point to work from. This feature would save the state of the build to the file system for faster cold starts. Issue #984 - Incremental on a Build Server: Cache the output folder between builds on a CI server like Netlify and only process/write templates that have changed since the last build. Issue #2775
- Global/directory/template Data file usage mapped to templates Issue #2706
- Template types
11ty.js
: Map JavaScript dependenciesliquid
: Dependency mapping for Liquid templates ({% include %}
, etc)Dependency mapping for Nunjucks templates (Unlikely due to Nunjucks API limitations.{% include %}
, etc)
- Collections dependencies improvements: while we have
eleventyImport.collections
to declaratively log collections dependencies, we may be able to dive deeper into template syntax APIs to find the symbols in use. Issue #1615 Alternatively we may be able to change the collections API to use Proxies to get smarter about this in an easier way (though previous experiments with this foreleventyComputed
failed in some languages). - Render plugin:
{% renderFile %}
dependencies - Stretch goal: Pagination-level incremental that operates on a subset of data Issue #1087