nestjs中使用小技巧

1.當(dāng)有多個Query參數(shù)時可以定義成對象, ApiQuery的type值設(shè)定為該對象類型占调。例如:

// xxx.dto.ts
export class QueryUserDto {
  @ApiProperty({ description: '用戶姓名' })
  @IsString()
  @IsOptional()
  name: string

  @ApiProperty({ description: 'limit, 默認為20' })
  @Type(() => Number)
  @IsNumber()
  @IsOptional()
  @Min(10)
  @Max(200)
  limit: number

  @ApiProperty({ description: 'offset, 默認為0' })
  @Type(() => Number)
  @IsNumber()
  @IsOptional()
  @Min(0)
  offset: number
}

// xxx.controller.ts
@ApiQuery({
    type: QueryUserDto
  })
  1. 好像Query參數(shù)不會自動轉(zhuǎn)類型(我的項目中是這樣的,不知道是設(shè)定問題還是BUG,需要手動添加Pipe坡倔,當(dāng)Query參數(shù)使用Class定義時很不方便)這時我們可以自己定義一個Pipe,使用plainToClass將對象轉(zhuǎn)成對應(yīng)的類型脖含。
// parse-query.pipe.ts
import type { ArgumentMetadata, PipeTransform } from '@nestjs/common'
import { Injectable } from '@nestjs/common'
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
import { ClassConstructor, plainToClass } from 'class-transformer'

@Injectable()
export class ParseQueryPipe implements PipeTransform<string> {
  async transform(value: any, { metatype }: ArgumentMetadata) {
    const obj = plainToClass(metatype as ClassConstructor<any>, value)
    console.log('metatype ---> ', metatype)
    return obj
  }
}

使用方法:

@Query(new ParseQueryPipe()) queryUserDto: QueryUserDto
  1. controller返回值統(tǒng)一使用固定的結(jié)構(gòu)時罪塔,生成swagger文檔可以參考https://docs.nestjs.com/openapi/operations#advanced-generic-apiresponse,使用泛型的方式器赞。
class BaseResponse<T> {
   data: T
   status: number
    message: string
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末垢袱,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子港柜,更是在濱河造成了極大的恐慌请契,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夏醉,死亡現(xiàn)場離奇詭異爽锥,居然都是意外死亡,警方通過查閱死者的電腦和手機畔柔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門氯夷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人靶擦,你說我怎么就攤上這事腮考」秃粒” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵踩蔚,是天一觀的道長棚放。 經(jīng)常有香客問我,道長馅闽,這世上最難降的妖魔是什么飘蚯? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮福也,結(jié)果婚禮上局骤,老公的妹妹穿的比我還像新娘。我一直安慰自己暴凑,他們只是感情好峦甩,可當(dāng)我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著搬设,像睡著了一般穴店。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上拿穴,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天泣洞,我揣著相機與錄音,去河邊找鬼默色。 笑死球凰,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的腿宰。 我是一名探鬼主播呕诉,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼吃度!你這毒婦竟也來了甩挫?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤椿每,失蹤者是張志新(化名)和其女友劉穎伊者,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體间护,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡亦渗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了汁尺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片法精。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出搂蜓,到底是詐尸還是另有隱情狼荞,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布帮碰,位于F島的核電站粘秆,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏收毫。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一殷勘、第九天 我趴在偏房一處隱蔽的房頂上張望此再。 院中可真熱鬧,春花似錦玲销、人聲如沸输拇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽策吠。三九已至,卻和暖如春瘩绒,著一層夾襖步出監(jiān)牢的瞬間猴抹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工锁荔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留蟀给,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓阳堕,卻偏偏與公主長得像跋理,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子恬总,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,828評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 背景 在本文中前普,我將使用Nest.js構(gòu)建一個CNode。 為什么這篇文章壹堰?我喜歡NodeJs拭卿,雖然我的NodeJ...
    jiayisheji閱讀 11,585評論 3 20
  • 管道是具有@Injectable()裝飾器的類。管道應(yīng)實現(xiàn)PipeTransform接口管道有兩個功能:1. 驗證...
    alfalfaw閱讀 566評論 0 0
  • 什么是NestJS Nest 是一個漸進的 Node.js 框架缀旁,可以在 TypeScript 和 JavaScr...
    強某某閱讀 28,032評論 7 17
  • 現(xiàn)在记劈,我們將探索如何使用 CFEngine 執(zhí)行一些常見的配置任務(wù)。在此過程中并巍,我們將遇到 CFEngine 語言...
    藍筆頭閱讀 479評論 0 0
  • 今天感恩節(jié)哎目木,感謝一直在我身邊的親朋好友。感恩相遇!感恩不離不棄刽射。 中午開了第一次的黨會军拟,身份的轉(zhuǎn)變要...
    迷月閃星情閱讀 10,551評論 0 11