Nello script #252 abbiamo visto come sia semplice estendere una classe JavaScript esistente utilizzando TypeScript. In quello script abbiamo aggiunto alla classe Array il metodo Distinct, mentre in questo script aggiungeremo il metodo SelectMany molto utilizzato nelle applicazioni .NET quando si manipolano gli array. Vediamo prima il codice.
declare global {
interface Array<T> {
selectMany<K>(callbackfn: (value: T, index: number, array: T[]) => K[], thisArg?: any): K[];
}
}
Array.prototype.selectMany = function (fn) {
return this.map(fn).reduce(function (x, y) { return x.concat(y); }, []);
};
La prima parte del codice rende il metodo SelectMany visibile a TypeScript, la seconda parte definisce il metodo nel prototype della classe Array. Il codice del metodo selectMany accetta in input una funzione che specifica quale proprietà dell'array originale vogliamo appiattire. Questa funzione viene passata al metodo map che torna un array con gli oggetti desiderati. Succesivamente il metodo reduce appiattisce l'array concatenando tra loro gli oggetti.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Aggiornare a .NET 9 su Azure App Service
Eseguire query in contemporanea con EF
Ottimizzare le performance usando Span<T> e il metodo Split
Creare un agente A2Acon Azure Logic Apps
Simulare Azure Cosmos DB in locale con Docker
Fornire parametri ad un Web component HTML
Escludere alcuni file da GitHub Secret Scanning
Managed deployment strategy in Azure DevOps
Testare il failover sulle region in Azure Storage
Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
Gestire gli accessi con Token su Azure Container Registry
Supportare la sessione affinity di Azure App Service con Application Gateway


