Skip to main content

Template-driven forms



Template-driven Forms in Angular


Template-driven forms are the traditional approach used for creating forms in Angular. This type of form uses directives and data binding to create a form within the template of your component. It is a simpler approach than the reactive forms and is suitable for basic forms and when you need fast development. Template-driven forms are created and managed by directives in the template, with the help of form-specific directives.



Creating a Template-driven Form


The easiest way to create a template-driven form is by using the ngModel directive. To create a form, you need an Angular component, and in the template of the component, you add the HTML form elements, such as input and button. You also need to add an attribute called ngModel to each of the form elements, which acts as a two-way binding between the form element and the component property.



Example of a Template-driven Form


Let's create a simple template-driven form to understand the concept better. Here we have a component with a template containing a form with two input elements, one button element, and one div element. The div element will display the data entered into the input elements, and the button element will submit the form.



import { Component } from '@angular/core';

@Component({
selector: 'app-form',
template: `
<form (ngSubmit)="onSubmit()">
<label>Name</label>
<input type="text" [(ngModel)]="name" name="name"/>
<label>Age</label>
<input type="number" [(ngModel)]="age" name="age"/>
<button type="submit">Submit</button>
</form>
<div>
Name: {{name}}
<br />
Age: {{age}}
</div>
`
})
export class FormComponent {
name = '';
age = 0;

onSubmit() {
console.log(this.name, this.age);
}
}


Tips for Using Template-driven Forms



  • Make sure that the name attribute is set for each input element, as this is required for the ngModel directive to work.

  • Use the ngModelGroup directive to group related input elements together.

  • Always use the ngSubmit directive on the form element. This will trigger the onSubmit() method when the user clicks the submit button.

  • Use the ngModelChange directive to detect changes to the form values and perform the necessary actions.



Conclusion


Template-driven forms are a simple and straightforward approach to creating forms in Angular. They are suitable for basic forms and when you need fast development. Template-driven forms are created and managed by directives in the template, with the help of form-specific directives. Make sure to use the ngModel directive and the name attribute, and use the ngModelGroup and ngSubmit directives for better control over your form.