I have a list of questions with answer options as radio button field. I'm getting these questions and answers from JSON file.so am iterating over it on HTML and assigning values to formControlName dynamically. My problem is how to validate while iterating over control values?
*ngIf="cricketForm.control.get('ques{{i}}').invalid"
*ngIf="cricketForm.control.get('ques{{i}}').invalid"
this gives me an error. How to do it in the correct way?
https://stackblitz.com/edit/angular-yq4lyz-zt9b3h?file=app/form-field-overview-example.html Right now validation is not working correctly
html file:
<form [formGroup]="cricketForm">
<div *ngFor = "let user of userJson; let i =index ">
<div class="label1" for="NameId">{{user.question}}</div>
<mat-radio-group formControlName="ques{{i+1}}" aria-label="Select an option">
<div *ngFor = "let option of user.options; let j =index">
<mat-radio-button [value]=j>{{option}}</mat-radio-button>
</div>
</mat-radio-group>
<div class="invalid-feedback" *ngIf="cricketForm.control.get('ques{{i}}').invalid" >This field is required</div>
</div>
<button (click)="onSubmit()">Submit</button>
<button (click)="onReset()">Reset</button>
</form>
ts file:
ngOnInit() {
this.cricketForm = this.formBuilder.group({
ques1: [null, [Validators.required]],
ques2: [null, [Validators.required]],
ques3: [null, [Validators.required]],
ques4: [null, [Validators.required]]
})
this.userDataService.getJSON().subscribe(data => {
console.log(data);
this.userJson = data;
this.options = data.options
});
}
Sample JSON Data:
[
{"question": "Who Was The First Indian To Hit A Test Century?", "options":["Lala Amarnath","Kapil Dev", "Sunil Gavaskar"],"ans":"Lala Amarnath"},
{"question":"Who Won The Inaugural Asia Cup Championship?","options":["Pakistan","Sri Lanka", "India"],"ans":"India"},
{"question":"Who Was Australia’s First Captain?","options":["F.S.Jackson"
,"D.W. Gregory", "Tony Lewis"],"ans":"D.W. Gregory"},
{"question":" When And Where Was The First Ranji Trophy Match Played?","options":["kolkata"
,"Mumbai", "Chennai"],"ans":"Chennai"}
]