Nestjs 中的元类型是什么?

igo*_*gor 0 typescript nestjs

阅读 Nestjs 官方文档,我发现了以下实现ValidationPipe

import { PipeTransform, Injectable, ArgumentMetadata, BadRequestException } from '@nestjs/common';
import { validate } from 'class-validator';
import { plainToClass } from 'class-transformer';

@Injectable()
export class ValidationPipe implements PipeTransform<any> {
  async transform(value: any, { metatype }: ArgumentMetadata) {
    if (!metatype || !this.toValidate(metatype)) {
      return value;
    }
    const object = plainToClass(metatype, value);
    const errors = await validate(object);
    if (errors.length > 0) {
      throw new BadRequestException('Validation failed');
    }
    return value;
  }

  private toValidate(metatype: Function): boolean {
    const types: Function[] = [String, Boolean, Number, Array, Object];
    return !types.includes(metatype);
  }
}
Run Code Online (Sandbox Code Playgroud)

我不明白该transform方法中的逻辑。如果有人能逐行解释这篇文章那就太好了。我认为问题源于我不太明白它ArgumentMetadata是什么以及它从何而来。

Jay*_*iel 5

Metatype是传递到管道中的对象的类类型,通过反射和一些魔法检索,但如果 您想 查看这里的 代码

本质上,如果你有@Body() body: MyCustomClass,那么元类型将等于MyCustomClass. 这对于该plainToClass方法来说是必要的,因此它知道将 JSON 序列化到哪个类中。如果您使用 JavaScript 或不提供类型,则元类型将是未定义的