Dans Effect-TS, diverses fonctions de mappage peuvent être appliquées aux valeurs à l'intérieur d'une option pour transformer, remplacer ou manipuler les valeurs contenues. Cet article explore différentes fonctions de mappage fournies par Effect-TS avec des exemples pratiques.
Utilisez O.map pour appliquer une fonction de transformation à la valeur à l'intérieur d'une option. Si l'option est Some, la fonction est appliquée ; sinon, le résultat est Aucun.
import { Option as O, pipe } from 'effect'; function mapping_ex01() { const some = O.some(1); // Create an Option containing the value 1 const none = O.none(); // Create an Option representing no value const increment = (n: number) => n + 1; console.log(pipe(some, O.map(increment))); // Output: Some(2) (since some contains 1 and 1 + 1 = 2) console.log(pipe(none, O.map(increment))); // Output: None (since none is None) }
Utilisez O.as pour remplacer la valeur à l'intérieur de l'option par une valeur constante fournie.
import { Option as O, pipe } from 'effect'; function mapping_ex02() { const some = O.some(1); // Create an Option containing the value 1 const none = O.none(); // Create an Option representing no value console.log(pipe(some, O.as('replaced'))); // Output: Some('replaced') (replaces 1 with 'replaced') console.log(pipe(none, O.as('replaced'))); // Output: None (since none is None) }
Le résultat est Some('replaced') pour l'option some et None pour l'option none, démontrant comment O.as remplace efficacement la valeur d'origine si elle existe.
Utilisez O.asVoid pour remplacer la valeur à l'intérieur de l'option par undefined.
import { Option as O, pipe } from 'effect'; function mapping_ex03() { const some = O.some(1); // Create an Option containing the value 1 const none = O.none(); // Create an Option representing no value console.log(pipe(some, O.asVoid)); // Output: Some(undefined) (replaces 1 with undefined) console.log(pipe(none, O.asVoid)); // Output: None (since none is None) }
Explication :
La sortie est Some(undefined) pour l'option some et None pour l'option none, démontrant comment O.asVoid remplace efficacement la valeur d'origine si elle existe.
Utilisez O.flatMap pour appliquer une fonction de transformation qui renvoie une option à la valeur si l'option est Some, et aplatissez le résultat.
import { Option as O, pipe } from 'effect'; function mapping_ex04() { const some = O.some(1); // Create an Option containing the value 1 const none = O.none(); // Create an Option representing no value const doubleIfPositive = (n: number) => (n > 0 ? O.some(n * 2) : O.none()); console.log(pipe(some, O.flatMap(doubleIfPositive))); // Output: Some(2) (since some contains 1 and 1 > 0) console.log(pipe(none, O.flatMap(doubleIfPositive))); // Output: None (since none is None) }
La sortie est Some(2) pour l'option some et None pour l'option none, démontrant comment O.flatMap aplatit le résultat de la transformation.
Utilisez O.flatMapNullable pour appliquer une fonction de transformation qui peut renvoyer une valeur nullable à la valeur si l'option est Some, et convertir le résultat en option.
import { Option as O, pipe } from 'effect'; function mapping_ex05() { const some = O.some({ a: { b: { c: 1 } } }); // Create an Option containing a nested object const none = O.none(); // Create an Option representing no value const getCValue = (obj: { a?: { b?: { c?: number } } }) => obj.a?.b?.c ?? null; console.log(pipe(some, O.flatMapNullable(getCValue))); // Output: Some(1) (extracts the nested value) console.log(pipe(none, O.flatMapNullable(getCValue))); // Output: None (since none is None) }
La sortie est Some(1) pour l'option some et None pour l'option none, démontrant comment O.flatMapNullable convertit le résultat de la transformation en option.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!