I'm using ReactiveFormsModule
of Angular2 to create a component that contains a form. Here is my code:
foo.component.ts:
constructor(fb: FormBuilder) {
this.myForm = fb.group({
'fullname': ['', Validators.required],
'gender': []
});
}
foo.component.html (with [formControl]
):
<div class="fields">
<div class="field">
<label>Fullname*</label>
<input type="text" [formControl]="myForm.controls.fullname"/>
</div>
</div>
<div class="inline fields">
<label for="gender">Gender</label>
<div class="field">
<div class="ui radio checkbox">
<input type="radio" name="gender" checked="" tabindex="0" class="hidden" [formControl]="myForm.controls.gender">
<label>Male</label>
</div>
</div>
<div class="field">
<div class="ui radio checkbox">
<input type="radio" name="gender" tabindex="0" class="hidden" [formControl]="myForm.controls.gender">
<label>Female</label>
</div>
</div>
</div>
foo.component.html (with formControlName
):
<div class="fields">
<div class="field">
<label>Fullname*</label>
<input type="text" formControlName="fullname"/>
</div>
</div>
<div class="inline fields">
<label for="gender">Gender</label>
<div class="field">
<div class="ui radio checkbox">
<input type="radio" name="gender" checked="" tabindex="0" class="hidden" formControlName="gender">
<label>Male</label>
</div>
</div>
<div class="field">
<div class="ui radio checkbox">
<input type="radio" name="gender" tabindex="0" class="hidden" formControlName="gender">
<label>Female</label>
</div>
</div>
</div>
Both ways work. But i cannot figure out what is the difference between using [formControl]
and formControlName
.
I believe you missed an important point:
[formGroup]
directive in the second example.formControlName
is used together with[formGroup]
to save your form multiple dot navigations. For example:Is equivalent to:
Now imagine nested
FormGroups
:)[formControl]
assigns a reference to theFormControl
instance you created to theFormControlDirective
.formControlName
assigns a string for the forms module to look up the control by name.If you create variables for the controls, you also don't need the
.
as mentioned by Harry, but I'd also suggest to use[formGroup]
instead because with more complicated forms this can become messy.There is a 3rd equivalency to the two provided in the accepted answer, which is this (not recommended):
Notice that we are still using the [formGroup] directive.
However, for this template to compile without error, then your component needs to declare the controls as AbstractControls and not FormControls:
myComponent.ts
However, please note that declaring AbstractControls is not recommended, so if you get the error
Cannot find control with unspecified name attribute
then it is probable you have mixed the styles or have declared your controls as AbstractControls.with
[formControl]
you can use Reactive programming advantages becauseFormControl
has a property namedvalueChanges
(I know this one right now, maybe there is more than that) which returns anObservable
which you can subscribe and use it. (for example, it is very useful in register scenarios which you want to check input email to be not repeated as soon as user change the value)From the Angular docs (https://angular.io/guide/reactive-forms):
Component
Template