您好,登錄后才能下訂單哦!
這篇文章主要介紹“Nest.js系列之Providers及模塊功能怎么使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Nest.js系列之Providers及模塊功能怎么使用”文章能幫助大家解決問題。
Providers
是Nest
的一個基本概念。提供者是一個大的分類,比如sevice
、repository
、factory
、helper
等都是提供者。可以通過constructor
注入依賴關系。對象之間可以創建各種關系。提供者只是一個用@Injectable()
裝飾的類
在控制器的文章中,知道了如何創建一個簡單的控制器,控制器中不應該包含過多的復雜任務處理邏輯,這部分的任務邏輯處理應該交給Providers
因為Nest可以面向對象的方式設計和組織依賴性,所以強烈建議遵循SOLID原則
SOLID 原則其實是用來指導軟件設計的,它一共分為五條設計原則,分別是:
單一職責原則(SRP)
開閉原則(OCP)
里氏替換原則(LSP)
接口隔離原則(ISP)
依賴倒置原則(DIP)
從創建一個簡單的服務開始,服務由控制器使用,服務其實也是一個提供者
import { Injectable } from '@nestjs/common'; import { User } from './interfaces/user.interface'; @Injectable() export class UsersService { private readonly users: User[] = []; create(user: User) { this.users.push(user); } findAll(): User[] { return this.users; } }
之前文章提到過可以使用命令快速創建一個服務 nest g service users
import { Controller, Get, Post, Body } from '@nestjs/common'; import { CreateUserDto } from './dto/create-user.dto'; import { UsersService } from './users.service'; import { User } from './interfaces/user.interface'; @Controller('users') export class CatsController { constructor(private usersService: UsersService) {} @Post() async create(@Body() createUserDto: CreateUserDto) { this.usersService.create(createUserDto); } @Get() async findAll(): Promise<User[]> { return this.usersService.findAll(); } }
通過實例可以看出,控制器如果想要使用服務,只需要將服務通過依賴注入的方式注入到控制器中
constructor(private usersService: UsersService) {}
Nest 是建立在強大的設計模式,通常稱為依賴注入。我們建議在官方的 Angular文檔中閱讀有關此概念的精彩文章。
在 Nest
中,借助 TypeScript 功能,管理依賴項非常容易,因為它們僅按類型進行解析。在下面的示例中,Nest
將 catsService
通過創建并返回一個實例來解析 CatsService
(或者,在單例的正常情況下,如果現有實例已在其他地方請求,則返回現有實例)。解析此依賴關系并將其傳遞給控制器的構造函數(或分配給指定的屬性):
constructor(private readonly catsService: CatsService) {}
現在我們已經定義了提供者(UsersService
),并且已經有了該服務的使用者(UsersController
),我們需要在 Nest
中注冊該服務,以便它可以執行注入。 為此,我們可以編輯模塊文件(app.module.ts
),然后將服務添加到@Module()
裝飾器的 providers
數組中。
import { Module } from '@nestjs/common'; import { UsersController } from './users/users.controller'; import { UsersService } from './users/users.service'; @Module({ controllers: [UsersController], providers: [UsersService], }) export class AppModule {}
提供者可以簡單理解為是服務,但是畢竟服務只是一種提供者。在nest中通過使用服務來做邏輯處理。
模塊是具有@Module()裝飾器的類,Nest使用模塊來組織代碼
每個nest程序至少有一個模塊,也就是根模塊。但是這是對于小應用來說的,對于大型程序來說,會擁有多個模塊,每個模塊擁有自己的功能。 @Module()裝飾器接受屬性對象
providers 由nest注入器實例化的提供者,并且可以至少在整個模塊中共享
controllers 必須創建的控制器
imports 導入模塊的列表,這些模塊導出了此模塊中所需要的提供者
exports 本模塊導出的可以用于其他模塊的提供者
默認情況下,該模塊封裝提供程序。這意味著無法注入既不是當前模塊的直接組成部分,也不是從導入的模塊導出的提供程序。因此,您可以將從模塊導出的提供程序視為模塊的公共接口或API。
通常來說,一個功能對應一個模塊,比如UsersController
和UsersService
應該屬于一個模塊,該模塊就稱為功能模塊
users/users.module.ts
import { Module } from '@nestjs/common'; import { UsersController } from './users.controller'; import { UsersService } from './users.service'; @Module({ controllers: [UsersController], providers: [UsersService], }) export class UsersModule {}
可以使用cli命令來創建一個模塊
nest g module cats
當寫好一個功能模塊之后,要把模塊導入到根模塊
import {Module} from '@nestjs/common'; import {UsersModule} from './users/users.module'; @Module({ imports: [CatsModule], }) export class ApplocationModule {}
nest默認情況下,模塊是單例,因此可以很輕松的在多個模塊之間共享同一個提供者實例
其實在nest中,每個模塊都是共享模塊,可以被任意模塊重復使用。但是如果要在幾個模塊共享某一個服務,比如UsersService,那就需要在它所屬的模塊中導出這個服務,放到exports數組中
import { Module } from '@nestjs/common'; import { UsersController } from './users.controller'; import { UsersService } from './users.service'; @Module({ controllers: [UsersController], providers: [UsersService], exports: [UsersService] }) export class UsersModule {}
每個導入UsersModule
的模塊都可以訪問UsersService
模塊不僅可以導出提供者,而且還可以導出自己導入的模塊
@Module({ imports: [CommonModule], exports: [CommonModule], }) export class CoreModule {}
提供者也可以注入到模塊中
import { Module } from '@nestjs/common'; import { UsersController } from './cats.controller'; import { UsersService } from './cats.service'; @Module({ controllers: [CatsController], providers: [CatsService], }) export class CatsModule { constructor(private readonly catsService: CatsService) {} }
有時候需要在任何地方導入相同的模塊,如果每個模塊都導入,就會很繁瑣,所以就有了全局模塊
import { Module, Global } from '@nestjs/common'; import { UsersController } from './users.controller'; import { UsersService } from './users.service'; @Global() @Module({ controllers: [UsersController], providers: [UsersService], exports: [UsersService], }) export class UsersModule {}
@Global
裝飾器使模塊成為全局作用域。 全局模塊應該只注冊一次,最好由根或核心模塊注冊。 在上面的例子中,CatsService
組件將無處不在,而想要使用 CatsService
的模塊則不需要在 imports
數組中導入 CatsModule
。
使一切全局化并不是一個好的解決方案。 全局模塊可用于減少必要模板文件的數量。 imports
數組仍然是使模塊 API 透明的最佳方式。
Nest
模塊系統包括一個稱為動態模塊的強大功能。此功能使您可以輕松創建可自定義的模塊,這些模塊可以動態注冊和配置提供程序。動態模塊在這里廣泛介紹。在本章中,我們將簡要概述以完成模塊介紹。
以下是一個動態模塊定義的示例 DatabaseModule
:
import { Module, DynamicModule } from '@nestjs/common'; import { createDatabaseProviders } from './database.providers'; import { Connection } from './connection.provider'; @Module({ providers: [Connection], }) export class DatabaseModule { static forRoot(entities = [], options?): DynamicModule { const providers = createDatabaseProviders(options, entities); return { module: DatabaseModule, providers: providers, exports: providers, }; } }Copy to clipboardErrorCopied
forRoot()
可以同步或異步(Promise
)返回動態模塊。
此模塊 Connection
默認情況下(在 @Module()
裝飾器元數據中)定義提供程序,但此外-根據傳遞給方法的 entities
和 options
對象 forRoot()
-公開提供程序的集合,例如存儲庫。請注意,動態模塊返回的屬性擴展(而不是覆蓋)@Module()
裝飾器中定義的基本模塊元數據。這就是從模塊導出靜態聲明的 Connection
提供程序和動態生成的存儲庫提供程序的方式。
如果要在全局范圍內注冊動態模塊,請將 global
屬性設置為 true
。
{ global: true, module: DatabaseModule, providers: providers, exports: providers, }Copy to clipboardErrorCopied
如上所述,將所有內容全局化不是一個好的設計決策。
所述 DatabaseModule
可以被導入,并且被配置以下列方式:
import { Module } from '@nestjs/common'; import { DatabaseModule } from './database/database.module'; import { User } from './users/entities/user.entity'; @Module({ imports: [DatabaseModule.forRoot([User])], }) export class AppModule {}Copy to clipboardErrorCopied
如果要依次重新導出動態模塊,則可以 forRoot()
在導出數組中省略方法調用:
import { Module } from '@nestjs/common'; import { DatabaseModule } from './database/database.module'; import { User } from './users/entities/user.entity'; @Module({ imports: [DatabaseModule.forRoot([User])], exports: [DatabaseModule], }) export class AppModule {}
關于“Nest.js系列之Providers及模塊功能怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。