Validation rule that allows you to check combinations of rules created with OR logical operations.
Implements: IValidationRule
Description
The OrRule class allows you to validate combinations of rules created with OR logical operations.
Important points
- When one of the combined rules returns no errors, then this rule also returns no errors.
- When all combined rules return errors, then this rule returns all the errors.
Constructors
Creates a new validation rule and sets its values.
public
constructor(…rules: IValidationRule[])
- rules: IValidationRule[] - list of rules to join with an OR operator.
Instance methods
validate
Validates a given value against this rule.
public
validate(path: string, schema: Schema, value: any, results: ValidationResult[]): void
- path: string - dot notation path to the value.
- schema: Schema - schema this rule is called from.
- value: any - value to be validated.
- results: ValidationResult[] - list with validation results.
Examples
let schema = new Schema()
.withRule(new OrRule(
new ValueComparisonRule("LT", 1),
new ValueComparisonRule("GT", 10)
));
schema.validate(0); // Result: no error
schema.validate(5); // Result: 5 must be less than 1 or 5 must be more than 10
schema.validate(20); // Result: no error