フォームが送信されていないとエラーが表示されます。私は研究を開始し、このウェブサイトから、以下の例のような入力に私を除いてhttps://toddmotto.com/angular-2-forms-template-driven"ngModel#something =" ngModel ""をテンプレート駆動型の動的フォーム要素に適用するにはどうすればよいですか?
<input
type="email"
placeholder="Your email address"
name="email"
ngModel
#userEmail="ngModel"
required>
プリティstraitforwardとシンプルを、ピックアップしてフォームのために、私は私の入力のそれぞれにngModel #something="ngModel
を追加する必要が発見しましたケースquestion-shell
のコンポーネントを作成し、テンプレート内でngIf
という条件をトリガーして、データ内のtemplate
フィールドに応じてテキストの入力を行うようにしました。原因ならば、それはそれに加えて名前、電話番号、ウェブサイトなどに使用されますので、私はちょうど全体としての私の入力に
ngModel
#email="ngModel"
を追加することはできません私のコンポーネントの性質に
<!-- SMALL TEXT INPUT -->
<ng-container *ngIf="Data.template == 'sm_input'">
<fieldset class="col-xs-12 col-sm-6 col-md-4">
<label class="form-group center-block">
<input class="form-control" type="hidden" [attr.value]="Data.question">
{{Data.question}}:
<input class="form-control"
[attr.id]="Data.id"
[attr.name]="Data.name"
[(ngModel)]="UserResponse.answer"
>
</label>
</fieldset>
</ng-container>
私はフォームの中に同じ名前の要素がたくさんあることを推測しています。フォーム全体で同じプロパティを再定義するだけで、不完全な結果が得られます。
は、これまでのところ、フォームが設定されている方法は、この
questionnaire template
<form #branding="ngForm" (ngSubmit)="onSubmit(branding)" class="col-xs-12">
<ng-container *ngFor="let a of Data?.sections">
<question-shell *ngFor="let b of a.questions" [Data]="b"></question-shell>
</ng-container>
<button type="submit" class="btn">Submit</button>
</form>
その後、question-shell
が、私はデータがバインドすることは、上記与えた例のように、HTMLの異なるチャンクを持っているように書きます。これをどうにかして動的に作成するために使用できるデータに値を格納する方法はありますか?ここにはプランカがありますが、ブートストラップが動作しないことは間違いありません。前もって感謝します。私が読んで、あなたが(それ自体でngModelを使用する場合
のためにこれを与えますno =)、name属性で指定された名前を使用してプロパティを自動的に追加します。 – cabey77
プランナーを作成できますか? – yurzui
私はちょうどプランカーを追加しました。 – Optiq