satisfies operator that can catch errors.
satisfies, developers can validate that the type of an expression matches some type, without changing the resulting type of the expression. This operator can be used to catch possible errors, such as ensuring that an object has all the keys of some type, but no more than that.
Also in TypeScript 4.9, the
in operator has been made more powerful when narrowing types that do not list the property. Instead of leaving them as is, the language will intersect their types with
npm install -D [email protected]
Other new capabilities and improvements in the TypeScript 4.9 beta:
- File watching is powered by file system events by default, only falling back to polling if developers fail to set up event-based watchers. This should provide a less resource-intensive experience when running
–-watchmode or running with a TypeScript-powered editor like Visual Studio Code or Visual Studio.
Promise.resolvenow uses the
Awaitedtype to unwrap Promise-like types passed to it. This means that it more often returns the right
Promisetype, but that improved type can break existing code if it was expecting
unknowninstead of a
- TypeScript now errors on direct comparisons against the NaN value and will suggest some variation of
A production release of TypeScript 4.9 is due in November, preceded by a release candidate. TypeScript 4.8 shipped on August 25, with correctness and consistency improvements as well as file watching fixes.