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
You don't have access to this class
Keep learning! Join and start boosting your career
If we are going to be knowing the pipes we must begin by defining them, a Pipe is a pure function, that is, a function that given a certain value will always return the same result.
Pipes do not modify the value of a data, they simply change the visual aspect, Angular uses the concept of Pipes for data transformation.
Angular has by default some pipes that you can use to transform numbers, dates or strings. Let's see the most important ones:
You can find more Pipes and how they work in the official Angular documentation.
Pipes are easily used in HTML by using the "|" character followed by the pipe name.
<div> {{ "hi I'm platzi" | uppercase }} </div> <div> {{ 1000 | currency:'USD' }} </div> </div>
In the above examples, the text HOLA SOY PLATZI
will be displayed in the view in all uppercase and the number 1000 in the format $1,000.00.
In some cases, the pipes receive configuration parameters, such as the case of the currency
pipe that receives :'USD'
to indicate the type of currency.
Contribution created with contributions from Kevin Fiorentino.
Contributions 16
Questions 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 😁
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 decimalDejo 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 de angular los debemos usar en el HTML, no se utilizan desde TypeScript.
Want to see more contributions, questions and answers from the community?