Angular
Tutorial Angular: Formularios con ngModel en Angular
Angular NgModel: vinculación de datos en formularios. Domina la vinculación de datos en formularios de Angular utilizando NgModel con ejemplos detallados.
ngModel
es una directiva de Angular que se utiliza para crear una conexión bidireccional entre el modelo de datos en tu componente y los elementos del formulario en la vista.
Esta directiva pertenece al módulo FormsModule
, lo que implica que debe importarse en tu aplicación para poder ser utilizada.
La conexión bidireccional proporcionada por ngModel
permite que cualquier cambio en el valor del formulario se refleje automáticamente en la propiedad correspondiente del modelo, y viceversa, cualquier cambio en el modelo también se refleja automáticamente en el formulario. Esto es especialmente útil para mantener sincronizados los datos y la interfaz de usuario (UI) sin necesidad de escribir código adicional para observar los cambios.
¿Cómo se utiliza ngModel
?
Para usar ngModel
en un formulario sencillo, se pueden seguir los siguientes pasos:
1.- Importar FormsModule
Se debe importar el módulo FormsModule
de @angular/forms
en el módulo donde se va a usar el formulario.
// app.module.ts
import { FormsModule } from '@angular/forms';
import { NgModule } from '@angular/core';
@NgModule({
imports: [ FormsModule ],
// ...
})
export class AppModule { }
Para aplicaciones standalone (sin módulo principal):
En aplicaciones standalone, se debe importar FormsModule
directamente en el componente donde se utilizará ngModel
.
// mi-formulario.component.ts
import { Component } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { CommonModule } from '@angular/common';
@Component({
selector: 'app-mi-formulario',
standalone: true,
imports: [FormsModule, CommonModule],
templateUrl: './mi-formulario.component.html',
styleUrls: ['./mi-formulario.component.css']
})
export class MiFormularioComponent {
// ...
}
2.- Crear un componente para el formulario
Ejecutar el siguiente comando para generar un nuevo componente llamado mi-formulario
:
ng generate component mi-formulario
Para aplicaciones standalone, usar:
ng generate component mi-formulario --standalone
3.- Definir la estructura del formulario en la plantilla del componente
En el archivo HTML del componente, puedes usar la sintaxis [(ngModel)]
para vincular un campo de formulario a una propiedad del modelo de tu componente:
<!-- mi-formulario.component.html -->
<form (ngSubmit)="onSubmit()">
<div>
<label for="nombre">Nombre:</label>
<input type="text" id="nombre" [(ngModel)]="nombre" name="nombre" required>
</div>
<div>
<label for="email">Email:</label>
<input type="email" id="email" [(ngModel)]="email" name="email" required>
</div>
<button type="submit">Enviar</button>
</form>
4.- Vincular los elementos del formulario a las propiedades del componente
En el archivo TypeScript del componente, se debe declarar la propiedad que se va a enlazar.
// mi-formulario.component.ts
import { Component } from '@angular/core';
@Component({
selector: 'app-mi-formulario',
templateUrl: './mi-formulario.component.html',
styleUrls: ['./mi-formulario.component.css']
})
export class MiFormularioComponent {
nombre = '';
email = '';
onSubmit() {
console.log('Nombre:', this.nombre);
console.log('Email:', this.email);
}
}
En este ejemplo:
- Usamos
ngModel
para vincular los campos del formulario con las propiedades del objetousuario
. - Aplicamos validaciones básicas como
required
yemail
. - El botón de envío se deshabilita si el formulario no es válido.
- Mostramos los datos enviados después de que el formulario se haya enviado.
Este ejemplo ilustra cómo ngModel
facilita la creación de formularios simples con validación básica y enlace bidireccional de datos.
También se utilizó la directiva [(ngModel)]
para vincular cada campo de entrada a una propiedad del componente y se añadió la etiqueta required
para indicar que ambos campos son obligatorios.
Inicialización de valores
Puedes inicializar las propiedades del modelo antes de que se cargue el componente y, automáticamente, estos valores aparecerán en los campos de los formularios vinculados:
export class AppComponent {
nombre: string = 'Juan';
}
Con este código, el campo de entrada se inicializará con el valor "Juan".
Uso con selectores y otros controles
ngModel
se puede usar no solo con inputs de texto, sino también con distintos tipos de inputs y selectores:
<select [(ngModel)]="paisSeleccionado" name="pais">
@for (pais of paises; track pais) {
<option [value]="pais">{{pais}}</option>
}
</select>
En el componente:
export class AppComponent {
paises: string[] = ['España', 'Francia', 'Alemania'];
paisSeleccionado: string = this.paises[0];
}
Validación de formularios
Una de las ventajas de usar NgModel
es la facilidad de implementar validaciones.
Angular proporciona varias directivas para validaciones predefinidas que se pueden aplicar directamente a los elementos del formulario:
required
: Campo obligatorio.minlength
: Número mínimo de caracteres.maxlength
: Número máximo de caracteres.pattern
: Expresión regular que debe cumplir el valor.
<form #formulario="ngForm">
<input name="nombre" [(ngModel)]="nombre" required minlength="5" maxlength="20" pattern="[a-zA-Z ]*">
@if (formulario.controls['nombre'].errors?.['required']) {
<div>El nombre es obligatorio</div>
}
@if (formulario.controls['nombre'].errors?.['minlength']) {
<div>El nombre debe tener al menos 5 caracteres</div>
}
@if (formulario.controls['nombre'].errors?.['maxlength']) {
<div>El nombre no puede exceder 20 caracteres</div>
}
@if (formulario.controls['nombre'].errors?.['pattern']) {
<div>El nombre solo puede contener letras y espacios</div>
}
</form>
ngModel
con objetos complejos
ngModel
no solo se limita a trabajar con tipos de datos simples, sino que también puede manejar objetos más complejos. Esto es útil cuando necesitas crear formularios que representen entidades con múltiples propiedades.
Veamos un ejemplo sencillo de cómo usar ngModel
con un objeto que tiene propiedades anidadas:
Primero, definimos el modelo de datos en el componente:
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
usuario = {
nombre: '',
direccion: {
calle: '',
ciudad: ''
}
};
getErrorMessages(control: AbstractControl | null): string[] {
if (!control || !control.errors) return [];
const messages = [];
if (control.errors['required']) {
messages.push('Este campo es obligatorio');
}
// Puedes agregar más mensajes para otros tipos de errores aquí
return messages;
}
onSubmit() {
console.log('Datos del usuario:', this.usuario);
}
}
Luego, creamos el formulario en la plantilla HTML:
<!-- app.component.html -->
<form (ngSubmit)="onSubmit()" #formulario="ngForm">
<div>
<label for="nombre">Nombre:</label>
<input id="nombre" [(ngModel)]="usuario.nombre" name="nombre" required>
</div>
<div ngModelGroup="direccion">
<div>
<label for="calle">Calle:</label>
<input id="calle" [(ngModel)]="usuario.direccion.calle" name="calle" required>
</div>
<div>
<label for="ciudad">Ciudad:</label>
<input id="ciudad" [(ngModel)]="usuario.direccion.ciudad" name="ciudad" required>
</div>
</div>
<button type="submit" [disabled]="!formulario.form.valid">Enviar</button>
</form>
En este ejemplo:
- Usamos
[(ngModel)]
para vincular cada campo del formulario con las propiedades del objetousuario
. - Utilizamos
ngModelGroup
para agrupar los campos relacionados con la dirección. - Aplicamos validaciones básicas como
required
. - El botón de envío se deshabilita si el formulario no es válido.
Para mostrar mensajes de error, podemos agregar al campo Nombre
:
<div>
<label for="nombre">Nombre:</label>
<input id="nombre" [(ngModel)]="usuario.nombre" name="nombre" required>
@for (error of getErrorMessages(formulario.controls['nombre']); track error) {
<span class="error-message">{{ error }}</span>
}
</div>
Esta estructura permite manejar objetos complejos de forma sencilla, manteniendo la sincronización entre el modelo de datos y el formulario. Además, facilita la agrupación lógica de campos relacionados y la aplicación de validaciones.
Ventajas y desventajas de ngModel
Ventajas:
- Facilidad de uso:
ngModel
simplifica el código al minimizar la cantidad de lógica requerida para el enlace de datos. - Rapidez de desarrollo: Ideal para prototipos y proyectos pequeños donde la velocidad de desarrollo es crucial.
Desventajas:
- Menos control: Ofrece menos control en comparación con las formas reactivas.
- Rendimiento: No es la opción más eficiente para formularios complejos y dinámicos.
Ejercicios de esta lección Formularios con ngModel en Angular
Evalúa tus conocimientos de esta lección Formularios con ngModel en Angular con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.
Signals en Angular
Guards funcionales
Decodificar JWT en Angular
Servicio con HttpClient
Ciclo de vida de componentes en Angular
Gestión de productos de Fake Store API
Data binding en Angular
Routes sin módulos en Angular
Router en Angular
Instalación de Angular
Route Guards basados en interfaces
La directiva @if en Angular
Formularios reactivos en Angular
Servicios en Angular
Interceptor funcional
Servicio con Array
La directiva @for en Angular
Interceptores HTTP
Componentes standalone true
Formularios con ngModel en Angular
Routes en Angular
Comunicación entre componentes Angular
Parámetros en rutas con ActivatedRoute
CRUD de Restaurantes y Platos
Tablas en Angular Material
Formulario de registro de usuarios
Instalación y uso de NgBoostrap
Desarrollo de componentes Angular
JWT en Angular
Formularios reactivos en Angular
Formularios en Angular Material
Layout con Angular Material
Effects en Angular
Data binding
HttpClient en servicios de Angular
Desarrollo de módulos Angular
Comandos Angular CLI
Subir archivo en formularios
La directiva routerLink en Angular
Todas las lecciones de Angular
Accede a todas las lecciones de Angular y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.
Instalación Angular
Introducción Y Entorno
Comandos Angular Cli
Introducción Y Entorno
Desarrollo De Componentes Angular
Componentes
Data Binding En Angular
Componentes
Ciclo De Vida De Componentes En Angular
Componentes
Comunicación Entre Componentes Angular
Componentes
La Directiva @If En Angular
Componentes
La Directiva @For En Angular
Componentes
Componentes Standalone
Componentes
Desarrollo De Módulos Angular
Módulos
Routes En Angular
Enrutado Y Navegación
Router En Angular
Enrutado Y Navegación
La Directiva Routerlink En Angular
Enrutado Y Navegación
Parámetros En Rutas Con Activatedroute
Enrutado Y Navegación
Routes Sin Módulos En Angular
Enrutado Y Navegación
Servicios En Angular
Servicios E Inyección De Dependencias
Httpclient En Servicios De Angular
Servicios E Inyección De Dependencias
Formularios Con Ngmodel En Angular
Formularios
Formularios Reactivos En Angular
Formularios
Subir Archivo En Formularios
Formularios
Layout Con Angular Material
Integración Con Angular Material
Tablas En Angular Material
Integración Con Angular Material
Formularios En Angular Material
Integración Con Angular Material
Instalación Y Uso De Ngboostrap
Integración Con Bootstrap Css
Signals En Angular
Signals Y Reactividad
Effects En Angular
Signals Y Reactividad
Route Guards Basados En Interfaces
Autenticación Y Autorización
Guards Funcionales
Autenticación Y Autorización
Interceptores Http Basados En Interfaz
Autenticación Y Autorización
Interceptores Http Funcionales
Autenticación Y Autorización
Seguridad Jwt En Angular
Autenticación Y Autorización
Decodificar Tokens Jwt En Angular
Autenticación Y Autorización
Certificados de superación de Angular
Supera todos los ejercicios de programación del curso de Angular y obtén certificados de superación para mejorar tu currículum y tu empleabilidad.
En esta lección
Objetivos de aprendizaje de esta lección
- Comprender el concepto de
ngModel
en Angular. - Aprender a importar
FormsModule
para usarngModel
. - Entender cómo usar
ngModel
para crear formularios. - Conocer las ventajas y desventajas de usar
ngModel
.