Para ver mas sobre los pipe
https://aristotekean.medium.com/tipos-de-pipes-en-angular-d736079491b1
Componentes
Todo lo que aprenderás sobre componentes y servicios en Angular
¿Qué son los componentes?
Uso de Inputs
Uso de Outputs
Componente para producto
Ciclo de vida de componentes
ngDestroy and SetInput
Lista de productos
Componentes y Header
Implementando el sideMenu
Comunicación padre e hijo
Servicios
Conociendo los servicios
¿Qué es la inyección de dependencias?
Obteniendo datos de una API
Pipes y Directives
Conociendo los pipes
Construyendo tu propio pipe
Conociendo las directivas
Best practices
Reactividad básica
Guia de estilos de Angular y linters
Despedida
Despedida
No tienes acceso a esta clase
¡Continúa aprendiendo! Únete y comienza a potenciar tu carrera
Nicolas Molina
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.
Angular posee por defecto algunos pipes que puedes utilizar para transformar números, fechas o cadenas de texto. Veamos los más importantes:
Podrás encontrar en la documentación oficial de Angular más Pipes y su funcionamiento.
Los pipes se utilizan fácilmente en el HTML haciendo uso del carácter “|” seguido del nombre del pipe.
<div>
{{ "hola soy platzi" | uppercase }}
</div>
<div>
{{ 1000 | currency:'USD' }}
</div>
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.
Aportes 16
Preguntas 2
Para ver mas sobre los pipe
https://aristotekean.medium.com/tipos-de-pipes-en-angular-d736079491b1
Importante nota: Los pipes no se utilizan en el Typescript van directamente en el html!!!
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.
Me da la impresión que el video tiene un corte extraño en el minuto 3:00, como si se hubiera cortado una parte de la explicación
En el servicio:
app.module.ts
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppRoutingModule } from './app-routing.module';
**import { HttpClientModule } from '@angular/common/http';**
@NgModule({
declarations: [
...componentes
],
imports: [
...otros modulos,
**HttpClientModule**
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
ng g s services/products
Para usarlo debemos hacer una inyección de dependencias en nuestro servicio. En este caso el servicio HttpClient se inyecta sobre nuestro servicio products
import { Injectable } from '@angular/core';
**import { HttpClient } from '@angular/common/http';**
@Injectable({
providedIn: 'root'
})
export class ProductsService {
constructor(
**private http: HttpClient**
) { }
}
return this.http.get<Product[]>(”https://fakestoreapi.com/products”);
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:
id:string;
title: string;
price: number;
description**?**: string;
category**?**: string;
image: string;
rating**?**: {
"rate": 3.9,
"count": 120
}
Nota: Podemos usar ahora la interfaz dentro de los datos obtenidos desde la api para designar el tipo de variable dentro de nuestra petición
import { Injectable } from '@angular/core';
**import { HttpClient } from '@angular/common/http';
import { Product } from '../models/product.model';**
@Injectable({
providedIn: 'root'
})
export class ProductsService {
constructor(
private http: HttpClient
) { }
**getAllProducts(){
return this.http.get<Product[]>("https://fakestoreapi.com/products");
}**
}
En el componente:
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.
**import { ProductsService } from 'src/app/services/products.service';**
**constructor (
private storeService: StoreService,
private productsApi: ProductsService
){**
this.myShopingCart = this.storeService.getProductsOnCart();
**}**
**products : Product[] = [];**
**ngOnInit(): void{
this.productsApi.getAllProducts()
.subscribe(data => this.products = data);
}**
this.productsApi.getAllProducts()
**.subscribe(data => this.products = data);**
Este es el script completo:
import { Component, OnInit } from '@angular/core';
import { Product } from 'src/app/models/product.model';
import { StoreService } from 'src/app/services/store.service';
**import { ProductsService } from 'src/app/services/products.service';**
@Component({
selector: 'app-products',
templateUrl: './products.component.html',
styleUrls: ['./products.component.scss']
})
export class ProductsComponent {
**constructor (
private storeService: StoreService,
private productsApi: ProductsService
){**
this.myShopingCart = this.storeService.getProductsOnCart();
**}**
**products : Product[] = [];**
myShopingCart: Product[] = [];
countProductOnCart: number = 0;
totalProductOnCart: number = 0;
addProductToCart(producto:Product){
this.myShopingCart = this.storeService.addProductToCart(producto);
this.countProductOnCart = this.storeService.getCountProductsOnCart();
this.totalProductOnCart = this.storeService.getTotalProductOnCart();
}
**ngOnInit(): void{
this.productsApi.getAllProducts()
.subscribe(data => this.products = data);
}**
}
2050… vienes del futuro, eh?
Se pueden ver todos los pipes disponibles de Angular en la doc oficial:
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.
Super los Pipes muy aplicable para nuestros proyectos 😁
Dejo aqui buena documentación al respecto https://www.acontracorrientech.com/pipes-en-angular-guia-completa/
Documentación de los Pipes: https://angular.io/api/common#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 decimalLos pipes de angular los debemos usar en el HTML, no se utilizan desde TypeScript.
¿Quieres ver más aportes, preguntas y respuestas de la comunidad?