4

你好!我有一个关于类验证器的问题

我的客户将请求多个数字,我需要相互比较值。

我想要如下代码。

const validator: SomeValidator = new SomeValidator;
validator.first = 1000;
validator.second = 2000; // this will be greater than validator.first
validator.third = 3000; // this will be greater than validator.second

我尝试在@Min() 验证器中输入变量,如下所示

import { IsInt, Min } from 'class-validator';

class SomeValidator {

  @IsInt()
  @Min(0)
  public first: number;

  @IsInt()
  @Min(this.first) // it occurs TS7017
  public second: number;

  @IsInt()
  @Min(this.second) // it occurs TS7017
  public third: number;

}

我得到了TS7017 错误

TS7017: Element implicitly has an 'any' type because type 'typeof globalThis' has no index signature.

有没有完美的方法来处理这个?

我知道有如下简单的方法,但我希望有一些方法可以使用类验证器。

if ((first > second) || (second > third)) {
  res.status(400).json({
    message: 'validation failed',
  });
  return next(new Error('some error'));
4

1 回答 1

5

是的,您可以,但不是本机,在这种情况下,您需要创建自己的装饰器来实现此验证。这是一个例子:

首先创建你的装饰器验证器

// file validators/is-bigger-than.ts
import { registerDecorator, ValidationOptions, ValidationArguments } from 'class-validator';

export function IsBiggerThan(property: string, validationOptions?: ValidationOptions) {
  return function (object: Object, propertyName: string) {
    registerDecorator({
      name: 'isBiggerThan',
      target: object.constructor,
      propertyName: propertyName,
      constraints: [property],
      options: validationOptions,
      validator: {
        validate(value: any, args: ValidationArguments) {
          const [relatedPropertyName] = args.constraints;
          const relatedValue = (args.object as any)[relatedPropertyName];
          return typeof value === 'number' && typeof relatedValue === 'number' && value > relatedValue;
        },
      },
    });
  };
}

然后将其导入您的 dto

import { IsBiggerThan } from '../../validators/is-bigger-than';

export class SomeObjectDTO {
  minValue: number;


  @IsBiggerThan('minValue', {
    message: 'maxValue must be larger than minValue',
  })
  maxValue: number;
}
于 2021-06-03T03:35:59.043 回答