Unpacking the Latest Features of NestJS v10
Delving into the Enhancements and New Capabilities of NestJS's Latest Version
Introduction
NestJS v10 is here! This progressive Node.js framework offers efficient, reliable, and scalable server-side app building.
As per the StackOverflow Developer survey, NestJS is one of the top 10 most popular backend frameworks in the world. Check the survey results here.
It has more than 58k Github stars on its repository.
What's New?
Recently NestJS has officially released v10 for building efficient and enterprise-grade, server-side applications. Let's deep dive and see what are the new features of the new version.
SWC Integration
SWC stands for Speedy Web Compiler. It is an extensible Rust-based platform that can be used for both compilation and bundling. To speed up your development process, using SWC with NestJs CLI is a great way.
Installation of required packages is as follows:
$ npm install --save-dev @swc/cli @swc/core
You can now use SWC with NestJs CLI as follows:
$ nest start -b swc
# or
$ nest start --builder swc
Another way to use SWC by default is via nest-cli.json
file, as mentioned below:
{
"compilerOptions": {
"builder": "swc"
}
}
By default, SWC does not perform any type-checking itself, so to enable this option we need to use --type-check
flag, as mentioned below:
$ nest start -b swc --type-check
# or
$ nest start --builder swc --type-check
Redis Wildcard Subscriptions
Added support for Redis wildcard subscriptions. This feature allows one to subscribe to all messages that match a given pattern.
To start using Redis-based microservices, install the required packages as follows:
$ npm install ioredis
By default wildcard subscription is false,
to enable the wildcard subscription
const app = await NestFactory.createMicroservice(AppModule, {
transport: Transport.REDIS,
options: {
host: 'localhost',
port: 6379,
wildcard: true, // this is the new option available
},
});
With wildcards enabled, we can use glob-type patterns in our subscriptions, such as:
ne?tjs
subscribes tonestjs
,nextjs
andnuxtjs
ne*tjs
subscribes tonetjs
andneetjs
What's Improved or Changed?
Together with new changes, there are some improvements in the latest v10 of NestJS.
Changes to Cache Module
Caching is a great and simple technique to improve your app's performance.
The CacheModule
is now available as a standalone package @nestjs/cache-manager
. Earlier this package was available under @nestjs/common
To install the required packages:
$ npm install @nestjs/cache-manager cache-manager
Overriding Modules in tests
Overriding of modules in tests has been introduced in v10. This feature is useful when you want to mock the entire module all at once instead of mocking each provider individually.
CLI Plugins and TypeScript >= 4.8
NestJS CLI plugins will now require TypeScript >= v4.8. This is due to breaking changes in TypeScript v4.8.
Dropping Support for Node.js v12
Since Node.js v12 went end of life (EOL), to use the new features of NestJS v10, a minimum version of Node.js v16 or higher is required.
This also allows the NestJS package to be compiled as ES2021 by default which results in a smaller library size and better performance.
Migration Guidelines
To migrate your existing NestJS project to the latest version, follow the links available below:
Conclusion
NestJS v10 brings a lot of new exciting and improved features as compared to its older versions. If you are using NestJS in your projects please share it via comments.
I hope you have learned something new as I did. If so, kindly like it or share it with others so they can also see it.
References
Below are some of the references which you can follow for more in-depth knowledge