Angular 6嵌套动态电抗形式

时间:2018-06-23 16:46:24

标签: angular typescript angular6

我正在努力了解如何实现嵌套的ReactiveForm。 我有一系列问题和一系列答案。答案将在单选按钮组中。但是,我不知道每个问题有多少个问题或有多少个答案。我将从API中检索。

对于每个问题,都需要一个答案。

例如

    <form class="form-group" id="{{prefix+'QuestionsForm'}}" [formGroup]="Form">
            <div class="form-group" id=" 
                {{prefix+'QuestionsAnswers'+'_'+i}}" *ngFor="let question of questions; index as i;">
                <div class="row">
                    <div class="col-xs-1 question-col">{{(i+1)+'. '}}</div>
                    <div id="{{prefix+'Question'+'_'+i}}" class="col-xs-11 no-padding-left>{{question.question}}</div>
                </div>
                <!--<div class="alert alert-danger gap-top-small alert-dismissible fade in experian" role="alert" style="display: block;">
                    <div class="glyphicon glyphicon-remove-sign color5 floatLeft"></div>
                    <div class="left-indent-text-block">Please select an option.</div>
                </div>-->
                <div class="row space-bottom-large">
                    <div class="col-xs-12 space-top-large">
                        <div class="radio-button space-top-small">
                            <div id="{{prefix+'Answers'+'_'+i}}" class="row space-left-large">
                                <div class="col-xs-12 space-bottom-large" *ngFor="let answer of question.answers; index as a">
                                    <input type="radio" name="{{'radio-group_'+i}}" id="{{prefix+'AnswerInput'+'_'+i+'_'+a}}" [value]="answer">
                                    <label id="{{prefix+'AnswerLabel'+'_'+i+'_'+a}}" for="{{prefix+'AnswerInput'+'_'+i+'_'+a}}">
                                        <span class="pull-left>
                                            {{answer}}
                                        </span>
                                    </label>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </form>

this.questions = [
    {
      question: "What is your favorite color?",
      answers: ["red", "blue", "green"]
    },
    {
      question: "What is your favorite animal?",
      answers: ["lion", "tiger", "dog", "cat"]
    },
    ..........
]

所以我认为ReactiveForm结构应该是:

Form: FormGroup(
  Questions: FormArray([
    Answers: FormArray([], Validators.required)
  ])
)

或者应该是:

Form: FormGroup(
  Questions: FormArray([
    Question: "",
    Answer: FormControl(Validators.required)
  ])
)

还是其他结构?

我不知道应该使用哪种ReactiveForm结构来构造表单以允许未知数量的问题和答案。但要求每个问题都选择一个答案。

非常感谢您的帮助。

2 个答案:

答案 0 :(得分:2)

您正在寻找的反应形式的结构是这样的:

FormGroup({
    Questions: FormArray([
        FormControl(Validators.required),
        FormControl(Validators.required),
        ...
    ])
})

基本上,您想为每个问题添加一个条目到FormArray。每个条目都包含一个单选按钮组的FormControl。因此,一个问题的所有答案都共享一个FormControl。

我还根据您的要求制作了一个Plunker示例:

Angular 6 nested dynamic reactive form radio button example

您可以将表单登录到Plunker控制台并进行调查。

希望这会有所帮助。

答案 1 :(得分:0)