Angular: 21.0.0 Release

Release date:
November 19, 2025
Previous version:
21.0.0-rc.3 (released November 17, 2025)
Magnitude:
4,036 Diff Delta
Contributors:
10 total committers
Data confidence:
Commits:

Top Contributors in 21.0.0

wagnermaciel
bencodezen
amysorto
aparzi
hawkgs
SkyZeroZx
kirjs
angular-robot
bampakoa
andrewseguin

Directory Browser for 21.0.0

All files are compared to previous version, 21.0.0-rc.3. Click here to browse diffs between other versions.

Loading File Browser...

Release Notes Published

common

| Commit | Description | | -- | -- | | feat - c795960ada | Add experimental support for the Navigation API (#63406) | | feat - 9eac43cf46 | Support of optional keys for the KeyValue pipe (#48814) | | feat - a1868c9d13 | update to cldr 47 (#64032) | | fix - 196fa500a3 | properly type ngComponentOutlet (#64561) | | refactor - 7a4b225c57 | improve typing of ngComponentOutletContent (#63674) | | refactor - 25f593ce2a | removengModuleFactory input of NgComponentOutlet (#62838) |

compiler

| Commit | Description | | -- | -- | | fix - ecea909bcc | don't choke on unbalanced parens in declaration block | | fix - 04dd75ba94 | support arbitrary nesting in :host-context() | | fix - f54cc4f28a | support commas in :host() argument | | fix - 814b2713f5 | support complex selectors in :nth-child() | | fix - aad6ced0ef | support one additional level of nesting in :host() |

compiler-cli

| Commit | Description | | -- | -- | | feat - 563dbd998c | Adds diagnostic for misconfigured @defer triggers (#64069) | | feat - 0571b335b9 | enable type checking of host bindings by default (#63654) | | fix - 5b55200edf | allow value to be set on radio fields | | fix - ab98b2425f | capture metadata for undecorated fields (#63957) | | fix - be7110342b | disallow compiling with the emitDeclarationOnly TS compiler option enabled (#61609) | | fix - bd322ca410 | do not flag custom control required inputs as missing when field is present | | fix - 471da8a311 | infer type of custom field controls | | fix - 96cb0cffda | infer types of signal forms set on native inputs | | fix - 71ab11ccf0 | make field detection logic more robust | | fix - 1f389b8b97 | missingStructuralDirective diagnostic produces false negatives (#64579) | | fix - 7fd3db0423 | remove internal syntax-related flags (#63787) | | fix - c371251e4c | report invalid bindings on form controls | | fix - 01290ab275 | use any when checking field interface conformance |

core

| Commit | Description | | -- | -- | | feat - 809a4ed8c1 | Add migration for zoneless by default. (#63042) | | feat - 2a7a5de53f | Allow passing application providers in bootstrapModule options (#64354) | | feat - 28926ba92c | introduce BootstrapContext for improved server bootstrapping (#63562) | | feat - c2d376b85a | make SimpleChanges generic (#64535) | | feat - ad2376435b | support IntersectionObserver options in viewport triggers (#64130) | | feat - 539717f58a | support regular expressions in templates (#63887) | | fix - ab415f3d7f | control not recognized when input has directive injecting ViewContainerRef (#64368) | | fix - f008045ded | do not rename ARIA property bindings to attributes (#63925) | | fix - 1352fbdbf2 | Drop special-case disables automatic change detection scheduling (#63846) | | fix - c0791e1887 | drop support for TypeScript 5.8 (#63589) | | fix - aa389a691b | ensure @for iteration over field is reactive (#64113) | | fix - fec7c288e9 | Error on invalid APP_ID (#63252) | | fix - d399d7d02b | Explicit Zone CD in TestBed providers should not override TestBed error handler (#63404) | | fix - 92e09adc0a | Remove ignoreChangesOutsideZone option (#62700) | | fix - 45fed3d201 | Remove Zone-based change provider from internals by default (#63382) | | fix - c9f977833e | skip Angular formatting when formatting signals recursively | | fix - 67fbd5ff1e | SSR error in signal forms | | fix - c241038111 | update symbols (#64481) | | refactor - a5e5dbbc16 | remove moduleId from Component metadata (#63482) | | refactor - 9a16718b13 | remove deprecated interpolation option on Components. (#63474) |

elements

| Commit | Description | | -- | -- | | fix - be0455adda | return value on signal input getter (#62113) |

forms

| Commit | Description | | -- | -- | | feat - a278ee358c | add debounce() rule for signal forms | | feat - b8314bd340 | add experimental signal-based forms (#63408) | | feat - 0dd95c503f | Add FormArrayDirective (#55880) | | feat - d201cd2c2b | Prevents marking fields as touched/dirty when state is hidden/readonly/disabled (#63633) | | fix - 9c5e969f51 | bind invalid input in custom controls (#64526) | | fix - 10ef96adb3 | consistent treatment of empty (#63456) | | fix - d89e522a1f | debounce updates from interop controls | | fix - c0d88c37c9 | Emit FormResetEvent when resetting control (#64024) | | fix - 94b0afec00 | implement interoperability between signal forms and reactive forms (#64471) | | fix - a1ac9a6415 | interop supports CVAs with signals (#64618) | | fix - 505bde1fed | mark field as dirty when value is changed by ControlValueAccessor (#64471) | | fix - 3529877772 | mark field as dirty when value is changed by a bound control (#64483) | | fix - fd9af2afaf | only propagate schema defined properties from field to control (#64446) | | fix - 91d8d55a80 | Set error message of a schema error. | | fix - f4d1017c25 | test that common field states are propagated to controls (#63884) | | fix - acd7c83597 | test that min/max properties are propagated to controls (#63884) | | fix - 71e8672837 | test that minLength/maxLength properties are propagated to controls (#63884) | | perf - 507b3466ee | implement change detection for field control bindings | | perf - 781a3299f9 | only update interop controls when bound field changes | | perf - 32f86d35f7 | optimize [field] binding instructions (#64351) |

http

| Commit | Description | | -- | -- | | feat - 2739b7975b | add referrerPolicy option to HttpResource (#64283) | | feat - 07e678872f | Add reponseType property to HttpResponse and HttpErrorResponse (#63043) | | feat - 5cbdefcf11 | add support for fetch referrerPolicy option in HttpClient (#64116) | | feat - 4bed062bc9 | Provide http services in root (#56212) | | refactor - 0e4e17cd97 | HttpResponseBase.statusText (#64176) |

language-server

| Commit | Description | | -- | -- | | fix - 3f7111a9c3 | fix directory renaming on Windows |

language-service

| Commit | Description | | -- | -- | | fix - 89095946cf | address potential memory leak during project creation | | fix - 80e00ff4e5 | prevent interpolation from superseding block braces (#64392) |

migrations

| Commit | Description | | -- | -- | | feat - 6ddb250391 | add migration to convert ngClass to use class (#62983) | | feat - 8dc8914c8a | add migration to convert ngStyle to use style (#63517) | | feat - 861cee34e0 | Adds migration for deprecated router testing module (#64217) | | feat - 75fc16b261 | Adds support for CommonModule to standalone migration (#64138) | | fix - 655a99d0c6 | fix bug in ngclass-to-class migration (#63617) | | fix - 62bbce63b7 | remove error for no matching files in control flow migration (#64253) |

platform-browser

| Commit | Description | | -- | -- | | refactor - ce8db665f9 | remove deprecated ApplicationConfig export (#63529) |

router

| Commit | Description | | -- | -- | | feat - 4e0fc81491 | convert lastSuccessfulNavigation to signal (#63057) | | fix - 5e61e8d3c3 | Fix memory leak through Navigation.abort and canDeactivate guards (#64141) | | fix - f6a73f1913 | Respect custom UrlSerializer handling of query parameters (#64449) | | fix - 5b53535dd1 | Update recognize stage to use internally async/await (#62994) |

upgrade

| Commit | Description | | -- | -- | | fix - f86846555b | Remove deprecated UpgradeAdapter (#61659) |

Breaking Changes

common

  • (test only) - TestBed now provides a fake PlatformLocation implementation that supports the Navigation API. This may break some tests, though we have not observed any failures internally. You can revert to the old default for TestBed by providing the MockPlatformLocation from @angular/common/testing in your providers: {provide: PlatformLocation, useClass: MockPlatformLocation}
  • ngComponentOutletContent is now of type Node[][] | undefined instead of any[][] | undefined.
  • NgModuleFactory has been removed, use NgModule instead. ### compiler-cli
  • * Previously hidden type issues in host bindings may show up in your builds. Either resolve the type issues or set "typeCheckHostBindings": false in the angularCompilerOptions section of your tsconfig.
  • The Angular compiler now produces an error when the the emitDeclarationOnly TS compiler option is enabled as this mode is not supported. ### core
  • The server-side bootstrapping process has been changed to eliminate the reliance on a global platform injector.

Before: ts const bootstrap = () => bootstrapApplication(AppComponent, config);

After: ts const bootstrap = (context: BootstrapContext) => bootstrapApplication(AppComponent, config, context);

A schematic is provided to automatically update main.server.ts files to pass the BootstrapContext to the bootstrapApplication call.

In addition, getPlatform() and destroyPlatform() will now return null and be a no-op respectively when running in a server environment. - Using a combination of provideZoneChangeDetection while also removing ZoneJS polyfills will no longer result in the internal scheduler being disabled. All Angular applications now consistenly use the same scheduler, and those with the Zone change detection provider include additional automatic scheduling behaviors based on NgZone stabilization. - * TypeScript versions less than 5.9 are no longer supported. - (test only) - Using provideZoneChangeDetection in the TestBed providers would previously prevent TestBed from rethrowing errors as it should. Errors in the test will now be rethrown, regardless of the usage of provideZoneChangeDetection. Tests should be adjusted to prevent or account for these errors. As in previous major versions, this behavior can be disabled with rethrowApplicationErrors: false in configureTestingModule as a last resort. - ignoreChangesOutsideZone is no longer available as an option for configuring ZoneJS change detection behavior. - Angular no longer provides a change detection scheduler for ZoneJS-based change detection by default. Add provideZoneChangeDetection to the providers of your bootstrapApplication function or your AppModule (if using bootstrapModule). This provider addition will be covered by an automated migration. - moduleId was removed from Component metadata. - The interpolation option on Components has been removed. Only the default {{ ... }} is now supported.

elements

  • Fix signal input getter behavior in custom elements.

Before this change, signal inputs in custom elements required function calls to access their values (elementRef.newInput()), while decorator inputs were accessed directly (elementRef.oldInput). This inconsistency caused confusion and typing difficulties.

The getter behavior has been standardized so signal inputs can now be accessed directly, matching the behavior of decorator inputs:

Before: - Decorator Input: elementRef.oldInput - Signal Input: elementRef.newInput()

After: - Decorator Input: elementRef.oldInput - Signal Input: elementRef.newInput

forms

  • This new directive will conflict with existing FormArray directives or formArray inputs on the same element. ### platform-browser
  • The deprecated ApplicationConfig export from @angular/platform-browser has been removed. Please import ApplicationConfig from @angular/core instead. ### router
  • lastSuccessfulNavigation is now a signal and needs to be invoked
  • Router navigations may take several additional microtasks to complete. Tests have been found to often be highly dependent on the exact timing of navigation completions with respect to the microtask queue. The most common fix for tests is to ensure all navigations have been completed before making assertions. On rare occasions, this can also affect production applications. This can be caused by multiple subscriptions to router state throughout the application, both of which trigger navigations that happened to not conflict with the previous timing. ### upgrade
  • UpgradeAdapter is no longer available. Use upgrade/static instead ### zone.js
  • IE/Non-Chromium Edge are not supported anymore. ## Deprecations ### http
  • HttpResponseBase.statusText is deprecated