好的,假设我正在尝试根据枚举的值有条件地验证对象,我该怎么做?
这是验证对象的示例调用。
MyObjectValidator validator = new MyObjectValidator();
ValidationResult results = validator.Validate(new MyObject());
这是具有枚举值的类的示例。
public class MyObjectValidator : AbstractValidator<MyObject>
{
public MyObjectValidator()
{
RuleFor(x => x.anEnum).Equal(MyObject.MyEnum.First).SetValidator(new FirstValidator());
}
}
public class FirstValidator : AbstractValidator<MyObject>
{
public FirstValidator()
{
RuleFor(x => x.someDecimal).Equal(1).WithMessage("Decimal must equal 5 with anEnum set to First");
}
}
public class MyObject
{
public enum MyEnum : int
{
First = 0,
Second = 1,
Third = 2
}
public decimal someDecimal { get; set; }
public MyEnum anEnum { get; set; }
public MyObject()
{
anEnum = MyEnum.First;
someDecimal = 5;
}
}
此特定示例引发消息:“验证器 'FirstValidator' 无法验证 'MyEnum' 类型的成员 - 类型不兼容。”
经过一些编辑,我想出了一个包装器来做我希望的事情,但我更喜欢一个更优雅的解决方案。我将 MyObjectValidator 替换为
public MyObjectValidator()
{
RuleFor(x => x.anEnum).SetValidator(new ValidatorWrapper<MyObject>()).When(x => x.anEnum == MyObject.MyEnum.First);
}
并添加了一个验证器包装器
public class ValidatorWrapper<T> : PropertyValidator
{
public ValidatorWrapper() : base("Validator Message")
{
}
protected override bool IsValid(PropertyValidatorContext context)
{
MyObject myObj = (MyObject)context.Instance;
FirstValidator validator = new FirstValidator();
ValidationResult results = validator.Validate(myObj);
}
}
有没有办法在不必提供 propertyvalidator 包装器的情况下引用内部上下文,以便我可以根据枚举值有条件地验证许多规则?