Writing in the front
I’ve learned Typescript from a white perspective and summarized the TS series of articles, hoping to help readers. After learning the basics of TS, this series will explain how to practice development with the Node server framework of Nest.js.
Nest (NestJS) is a framework for building efficient, scalable Node.js server-side applications. It uses progressive JavaScript, is built in TypeScript and fully supports (but still allows developers to code in pure JavaScript), and combines elements of OOP (object-oriented programming), FP (functional programming), and FRP (functional responsive programming).
Nest uses the powerful HTTP Server framework, which supports the Express framework by default and is easy to use. Nest is abstracted on Express, combined with TS powerful language system to achieve efficient and fast development.
Nest is the Node framework that I am interested in after contacting the Express framework. I am familiar with it, so it is easy to choose Nest. Nest had 37.7K statuses on Github at the time of this article, which is proof of its popularity.
Nest provides an out-of-the-box application architecture that allows developers and teams to create highly testable, scalable, loosely coupled, and easy to maintain applications. The architecture is inspired by Angular.
Project creation
The development environment
Before the project starts, introduce the development environment first:
- Node. Js: 14.15.1
- Typescript: 3.8.3
- Nest. Js: 7.6.15
Prerequisites Ensure that node.js is installed on your operating system (>= 10.13.0, except V13).
Create a project
To create a project using the Nest CLI, install the scaffolding and run the following command to create your first Nest project.
$ npm i -g @nestjs/cli
$ nest new project-name
Copy the code
It can also be created using the yarn command:
$ yarn add @nest/cli
$ nest new project-name
Copy the code
After entering the preceding command, the following information is displayed:
G:\Code> Nest new Nest -test ⚡ We will scaffold your app in a few seconds.. CREATE nest-test/.eslintrc.js (631 bytes) CREATE nest-test/.prettierrc (51 bytes) CREATE nest-test/nest-cli.json (64 bytes) CREATE nest-test/package.json (1971 bytes) CREATE nest-test/README.md (3339 bytes) CREATE nest-test/tsconfig.build.json (97 bytes) CREATE nest-test/tsconfig.json (339 bytes) CREATE nest-test/src/app.controller.spec.ts (617 bytes) CREATE nest-test/src/app.controller.ts (274 bytes) CREATE nest-test/src/app.module.ts (249 bytes) CREATE nest-test/src/app.service.ts (142 bytes) CREATE nest-test/src/main.ts (208 bytes) CREATE nest-test/test/app.e2e-spec.ts (630 bytes) CREATE nest-test/test/jest-e2e.json (183 bytes) ? Which Package Manager would you ❤️ to use? Yarn ▹▹▹▸▹ Installation in progress... ☕Copy the code
As shown above, you are asked to choose YARN or NPM for package management. In this case, YARN is selected.
🚀 Successfully created project nest-test
👉 Get started with the following commands:
$ cd nest-test
$ yarn run start
Thanks for installing Nest 🙏
Please consider donating to our open collective
to help us maintain this package.
🍷 Donate: https://opencollective.com/nest
Copy the code
After years of quiet good, the computer background has been for us to carry forward, the final creation of success.
According to the above tips, we entered the project for operation, and the project directory is as follows:
Run yarn start or NPM run start to run the project and start the project service.
At this point, type http://localhost:3000 in the browser address bar to see ‘Hello World’.
Details are introduced
routing
When you open the main.ts file in the SRC directory, you see route prefixes in the @Controller() decorator to make routing groups easier and minimize code duplication.
main.ts
import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
async function bootstrap() {
const app = await NestFactory.create(AppModule);// Indicates that the Nest factory function was used to create the AppModule
await app.listen(3000);// Indicates that the project listens on port 3000
}
bootstrap();
Copy the code
The controller controls the display of incoming requests back to the client, and can also add specified routes. We can add the following code to the app.controller.ts file:
@Get("/home")
getHome(): string {
return "my home";
}
Copy the code
Run to get:
Set the local route prefix
You can also set local and global prefixes to avoid conflicts when all routes share common prefixes.
Writing best at @controller () indicates that all routing Settings in the current file are prefixed with best. As follows:
@Controller("best")
export class AppController {
constructor(private readonly appService: AppService) {}
@Get()
getHello(): string {
return this.appService.getHello(); }}Copy the code
Running results:
Set the global route prefix
You can set the global route front end by adding app.setGlobalPrefix() to the main.ts file:
app.setGlobalPrefix('nest-test'); // Global route prefix
Copy the code
Running results:
The controller controller
The controller is responsible for processing incoming requests and returning the response to the client. The purpose of the controller is to receive specific requests from the application. The controller receives control over which requesting bodies are routed. In many cases, each controller has multiple routes, and different routes can perform different actions.
To create a basic controller, we use classes and decorators. The decorator associates the class with the required metadata and enables Nest to create a routing map that binds the request to the appropriate controller.
app.controller.ts
import { Controller, Get } from '@nestjs/common';
import { AppService } from './app.service';
@Controller(a)export class AppController {
constructor(private readonly appService: AppService) {}
@Get()
getHello(): string {
return this.appService.getHello(); }}Copy the code
Similarly, we can use commands to create new controller modules to facilitate project management.
$ nest g controller users
Copy the code
The users directory file is now generated in SRC:
The initialized controller file is as follows:
users.controller.ts
import { Controller } from '@nestjs/common';
@Controller('users')
export class UsersController {}
Copy the code
Services business
As we saw in the controller file above, simple business logic can be handled, but in real development, the controller and business should be separated to decouple the code.
$ nest g service users
Copy the code
This generates a business file under the Users directory in SRC: users.service.ts
import { Injectable } from '@nestjs/common';
@Injectable(a)export class UsersService {
// Add the user's business logic
addUser(username: string.password: string) :string{
console.log(` create user: username -${username} password--${password}`);
return "add user success"; }}Copy the code
users.controller.ts
import { Body, Controller, Post } from '@nestjs/common';
import { UsersService }from "./users.service";
@Controller('users')
export class UsersController {
constructor(private readonly usersService: UsersService) {}Nest is built around a powerful design pattern commonly known as dependency injection. Nest sets UsersService by creating and returning an instance of UsersService.
@Post("add")
addUser(@Body() body){
return this.usersService.addUser(body.username,body.password); }}Copy the code
Using Postman to simulate user request, the result is as follows:
The Module Module
Modules are classes annotated with the @Module() decorator, which provides an organizational application structure for metadata utilization.
Each application has at least one module and one root module. The root module is the starting point Nest uses to build application diagrams – the internal data structures Nest uses to parse module and provider relationships and dependencies. Although it is theoretically possible for a very small application to have only the root module, this is not typical. We would like to emphasize that modules are highly recommended as an effective way to organize components. Thus, for most applications, the resulting architecture will have multiple modules, each encapsulating a closely related set of functions.
The @Module() decorator takes a single object whose attributes describe the Module:
providers | Providers that will be instantiated by the Nest injector and can at least be shared in this module |
---|---|
controllers | The set of controllers defined in this module that must be instantiated |
imports | Exports a list of imported modules for the providers required by this module |
exports | Providers The subset provided by this module should be available in other modules that import it |
How do we see the Service and Controller created above accessing and running?
Open app.modelu.ts and you can see:
import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { UsersController } from './users/users.controller';
import { UsersService } from './users/users.service';
@Module({
imports: [].controllers: [AppController, UsersController],
providers: [AppService, UsersService],
})
export class AppModule {}
Copy the code
After we create the submodules, we create UsersController and UsersService, which are routable without creating a new module file because the system automatically adds them to the app.module.ts file.
Of course, we can also create sub-module files as required by executing the following command:
$ nest g module users
Copy the code
Now you see the module submodule file generated:
The initialized file looks like this:
users.module.ts
import { Module } from '@nestjs/common';
@Module({})
export class UsersModule {}
Copy the code
You need to assemble the UsersController and UsersService of the Users module into the module file. In this way, when other modules want to introduce the Users module, they do not need to use both Controller and Service, which facilitates the management of this module.
app.module.ts
import { Module } from '@nestjs/common';
import { UsersController } from './users.controller';
import { UsersService } from './users.service';
@Module({
imports: [UsersModule],
controllers: [UsersController],
providers: [UsersService],
})
export class UsersModule {}
Copy the code
Of course, the app.module.ts file needs to be modified because the submodule already introduces Controller and Service.
import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
// import { UsersController } from './users/users.controller';
// import { UsersService } from './users/users.service';
import { UsersModule } from './users/users.module';
@Module({
imports: [UsersModule],
controllers: [AppController],
providers: [AppService],
})
export class AppModule {}
Copy the code
summary
This article focuses on the first project you created with Nest, giving a brief overview of the creation process and the module concepts used. This section describes routes, controllers, services, and modules. Subsequent concepts will be explained in detail. For more details, see the official documents.
Refer to the article
Nest.js From Zero to One (Part 1) : Project Creation & Routing & Modules
Nest Official Documentation
Write in the last
Thank you for reading, I will continue to share with you more excellent articles, this article reference a large number of books and articles, if there are mistakes and mistakes, hope to correct.
More latest articles please pay attention to the author digging gold account and public number front gravitation.