FormControl`s of nested FormGroup are ng-valid although FromGroup is ng-invalid

前端 未结 1 487
一生所求
一生所求 2021-01-14 09:06

I have a nested form group called \'grades\':

Although the nested form group \'grades\' has the ng-invalid class applied the children form controls do have applied t

相关标签:
1条回答
  • 2021-01-14 09:52

    Technically, the specific form controls bestGrade and worstGrade are valid according to their own validators. Only their group has an error. Angular can't know you which controls you would want to invalidate if the group becomes invalid. You could make the information whether there was that specific group validation error onto the specific controls if you wished, and this would result in them being bordered red when they are invalid OR their group has the match error.

    Without default, the order in which angular processes group validation and control validation would override any manual adding of ng-invalid on the control when the control becomes valid on its own (required condition fulfilled). This is why I am using another class here matchError rather than ng-invalid. Otherwise ng-invalid would be removed and replaced by ng-valid by the control validation after ng-invalid is added by ngClasses or equivalent class modification.

    So instead of

    <select formControlName="bestGrade">
    

    you could use

    <select [class.matchError]="schoolyearForm.get('grades').hasError('match')" formControlName="bestGrade">
    

    in the same way, instead of

    <select formControlName="worstGrade">
    

    you can use

    <select [class.matchError]="schoolyearForm.get('grades').hasError('match')" formControlName="worstGrade">
    

    Edit: As OP still had issues while using select tags instead of input (read chat), I have recommended also removing the double pristine-ness requirement from the validator itself (by convention, we normally would check this where errors are displayed instead). Because the OP still has issues, I have prepared a plunkr demonstrating a working dummy (and ugly) version of his app to help investigate the issue.

    The plunkr can be found at:

    https://plnkr.co/edit/Gt5skDUOXfEaxsZreOkh

    Edit 2: plnkr URL updated to deal with class setting order when validation are checked between group and individual group controls

    Edit 3: Adjusted the answer here itself to reflect the OP's need for without defaults as was already setup in the latest plnkr from Edit 2

    0 讨论(0)
提交回复
热议问题