Template-driven vs. Model-driven forms

In this lesson, we will learn about Angular forms, their different types, and the differences between these types.

We'll cover the following

Angular uses forms to handle user input. Angular provides the following two different approaches for managing this input.

  • Template-driven approach
  • Model-driven approach/Reactive approach

Let’s discuss each one of these.

Template-driven forms

Template-driven forms allow us to create simple forms where we can use directives likengModel. We need to import them using FormsModule from the @angular/forms package as they are not available by default like in AngularJS.

The following example shows a simple template-driven form.

<form #form="ngForm" (ngSubmit)="onSubmit()">
   <label>First Name:</label>
   <input type="text" [(ngModel)]="user.firstName" required>

    <label>Password:</label>
    <input type="password" [(ngModel)]="user.password" required>
    <button type="submit" [disabled]="!form.valid">Submit</button>
    </form>

This looks like a regular form taking input from the user for the name and password fields, and on the click of the Submit button, it submits the whole form if all the required fields are filled.

The important part to notice here is the use of [(ngModel)].

Recall from chapter 4, lesson 1, i.e., Binding the data in components, we discussed Two-way data binding.

The[(ngModel)] syntax is also known as banana in the box syntax. This basically creates a bi-directional flow of data in the forms. The user can input the value for a particular field and then display it back on the view by interpolating that field.

The form error states are applied to the form fields to track and display the errors. You can use the following CSS classes for this as well.

  • touched or untouched
  • valid or invalid
  • pristine or dirty

The best part about using template-driven forms is that both the validation and data binding is taken care of at the template level.

Angular then internally takes care of associating a form control field to every input, applies validation as specified in the input attribute, and does the data binding in the presence of the ngModel directive.

None of this works without importing the FormsModule. That is what allows you to do form-related stuff in Angular.

So, if you get to see some error like:

Can't bind to ngModel since it is not a known property of input.

It means, you either missed to import the FormsModule or imported it in the wrong file.

Reactive forms

In the template-driven approach, most of the logic is driven from the template, whereas in the reactive-driven approach, it resides in the component class, and there is very little code in the template.

A reactive form is developed by importing the ReactiveFormsModule from the @angular/forms package.

These are some important terms to know before you go ahead with creating a form based on the reactive approach.

  • FormControl
  • FormGroup
  • FormArray
  • FormBuilder
  • formGroupName
  • formControlName

We will see a complete demo of forms in the upcoming chapter.

Get hands-on with 1300+ tech skills courses.