Uso de Pipes en Angular: Transformación y Formatos
Resumen
Si vamos a estar conociendo los pipes debemos empezar por definirlos, un Pipe es una función pura, o sea, una función que dado un determinado valor siempre devolverá el mismo resultado.
Los Pipes no modifican el valor de un dato, simplemente le cambian el aspecto visual, Angular utiliza el concepto de Pipes para la transformación de datos.
Tipos de pipes
Angular posee por defecto algunos pipes que puedes utilizar para transformar números, fechas o cadenas de texto. Veamos los más importantes:
DatePipe: Modifica fechas de acuerdo al formato necesitado.
UpperCasePipe: Convierte todo el texto a mayúscula.
LowerCasePipe: Convierte todo el texto en minúscula.
CurrencyPipe: Convierte un número a la moneda o divisa necesitada.
En los ejemplos anteriores, se mostrará en la vista el testo HOLA SOY PLATZI completamente en mayúscula y el número 1000 en formato $1,000.00. En algunos casos, los pipes reciben parámetros de configuración, como el caso del pipe currency que recibe :'USD' para indicar el tipo de divisa.
Contribución creada con los aportes de Kevin Fiorentino.
Importante nota: Los pipes no se utilizan en el Typescript van directamente en el html!!!
Entendido, Gracias por la aclaración Bro.
Tengo experiencia con Angular y estoy haciendo estos cursos como repaso, la importancia de estar atento a nuevas herramientas. No sabía que había un pipe de fechas, particularmente usaba la librería moment(). Algo nuevo que aprendí en la clase 👏👏👏
Pipes
Los pipes son una herramienta de Angular que nos permite transformar visualmente la información, por ejemplo, cambiar un texto a mayúsculas o minúsculas, o darle formato de fecha y hora, formatos numéricos. El valor de la información transformada no cambia, sólo lo hace su aspecto.
Gracias por la explicacion tan clara!
Una pregunta, si quisiera almacenar una fecha con ese formato del pipe Date, ¿Cómo se haría? puesto que veo que los pipes son para mostrar los datos con el formato pero no para almacenarlos
Lo que puedes hacer para almacenar una fecha formateada con el datePipe, es usar el datePipe en el .ts de el componente o servicio (donde quede mejor según el orden de tu código)
Crear el servicio desde la terminal que se dedique a administrar las peticiones a una API. En este caso lo llamaremos products porque vamos a usar una api para obtener productos ficticios
ng g s services/products
Importar del módulo HttpClientModule la función HttpCliente en el servicio products e inyectar el servicio en el constructor. Esta librería nos permite manejar peticiones similares a librerías de REACT como axios.
Para usarlo debemos hacer una inyección de dependencias en nuestro servicio. En este caso el servicio HttpClient se inyecta sobre nuestro servicio products
Ahora podemos acceder al metodo para hace la petición de la API para poder llamarlo cuando desemos se recomienda implementarlo dentro de una función del servicio:
El api genera datos con una serie de datos que por buenas prácticas debe ser estipulada dentro de una interfaz que asigne el tipo de valor esperado. Puedes declararlos dentro de una carpeta models/nombreInterfaz.model.ts la siguiente estructura es la usada como products.model.ts:
Ahora podemos llamar el servicio para obtener los datos de los productos. Ten muy en cuenta que se trata de una petición asincrona y debes implementarla dentro de un Hook que pueda trabajar con estas peticiones. La más común es ngOnInit.
Importar el servicio donde manejaremos nuestro api
La libreria del modulo Http tiene un método denominado .subscribe con el vamos a obtener los datos que se han obtenido desde el Json que es la respuesta de la petición.
Importante mencionar que la transformación de los pipe solo es para mostrarla por pantalla, no puedes manipurala transformada, si se utiliza el pipe uppercase, y luego quieres trabajarla en el ts, esta no estará en uppercase en el ts.
Aquí la documentación oficial de Angular donde ofrece más información acerca del tema:
Super los Pipes muy aplicable para nuestros proyectos 😁
Alguien sabe como cambiar para que muestre el formato en español?
Tendrías que personalizarlo, yo lo hice de esta manera
<p>{{ date | date :"d 'de' MMM h:mm"}}</p>
Conociendo los pipes
Los pipes en Angular son una herramienta que permite transformar los datos que se muestran en la plantilla de una manera sencilla y flexible. Los pipes se utilizan para formatear, filtrar, ordenar y transformar datos de una variedad de maneras.
En general, los pipes reciben un valor de entrada y lo transforman en un valor de salida, que se muestra en la vista. Los pipes pueden encadenarse, lo que significa que se pueden aplicar varios pipes a la vez, lo que permite transformar aún más los datos.
{{ value | uppercase }}{{'dsa'| uppercase }}=>'DSA'
Algunos de los Pipes mas populares o utiles:
{{ value | uppercase }} - Convierte el valor en mayúsculas
{{ value | lowercase }} - Convierte el valor en minúsculas
{{ value | number }} - Formatea el valor numérico según las convenciones de formato regional
{{ value | date }} - Formatea la fecha según las convenciones de formato regional
{{ value | currency }} - Formatea el valor numérico como moneda según las convenciones de formato regional
{{ value | async }} - Permite trabajar con observables y promesas en la plantilla
{{ value | slice }} - Devuelve una parte de una cadena o un array
{{ value | json }} - Muestra el objeto como una cadena JSON
{{ value | percent }} - Convierte el valor en un porcentaje
{{ value | decimal }} - Formatea el valor numérico como decimal