Как мне следует условно требовать поле формы? Я сделал специальный валидатор, но условные переменные, которые я передаю в пользовательский валидатор, являются статическими и остаются их начальными значениями. Каким должен быть мой пользовательский валидатор для получения обновленных условных значений? Возможно, есть способ сделать это с помощью Validators.required
вместо настраиваемого валидатора?
private foo: boolean = false;
private bar: boolean = true;
constructor(private _fb: FormBuilder) {
function conditionalRequired(...conditions: boolean[]) {
return (control: Control): { [s: string]: boolean } => {
let required: boolean = true;
for (var i = 0; i < conditions.length; i++) {
if (conditions[i] === false) {
required = false;
}
}
if (required && !control.value) {
return { required: true }
}
}
}
this.applyForm = _fb.group({
'firstName': ['', Validators.compose([
conditionalRequired(this.foo, !this.bar)
])],
...
});
}
Обновление (17 мая 2016 года)
Прошло много времени с момента публикации, но я хотел бы ссылаться на методы .include()
и .exclude()
, доступные в классе ControlGroup
для всех, кто пытается создать эту функцию. (docs). Хотя существуют вероятные варианты использования условного валидатора, как указано выше, я нашел включение и исключение элементов управления, групп управления, и управляющие массивы - отличный способ справиться с этим. Просто установите валидатор required
на элемент управления, который вы хотите, и включите/исключите его, как вам будет угодно. Надеюсь, это поможет кому-то!