Effect-TS에서는 Option 내부의 값에 다양한 매핑 함수를 적용하여 포함된 값을 변환, 교체, 조작할 수 있습니다. 이 글에서는 Effect-TS가 제공하는 다양한 매핑 기능을 실제 사례와 함께 살펴봅니다.
옵션 내부 값에 변환 함수를 적용하려면 O.map을 사용하세요. Option이 Some이면 해당 기능이 적용됩니다. 그렇지 않으면 결과는 없음입니다.
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) }
O.as를 사용하여 Option 내부의 값을 제공된 상수 값으로 바꿉니다.
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) }
some Option에 대한 출력은 Some('replaced')이고 none 옵션에 대한 None입니다. 이는 O.as가 원래 값이 있는 경우 이를 효과적으로 대체하는 방법을 보여줍니다.
O.asVoid를 사용하여 Option 내부의 값을 정의되지 않은 값으로 바꿉니다.
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) }
설명:
some Option에 대한 출력은 Some(undefine)이고 none Option에 대한 출력은 None입니다. 이는 O.asVoid가 원래 값이 있는 경우 이를 효과적으로 대체하는 방법을 보여줍니다.
O.FlatMap을 사용하여 Option이 Some인 경우 해당 값에 Option을 반환하는 변환 함수를 적용하고 결과를 평면화합니다.
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) }
some Option에 대한 출력은 Some(2)이고 none Option에 대한 출력은 None이며, O.FlatMap이 변환 결과를 평면화하는 방법을 보여줍니다.
O.FlatMapNullable을 사용하여 Option이 Some인 경우 Null 허용 값을 값에 반환할 수 있는 변환 함수를 적용하고 결과를 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) }
일부 Option의 경우 출력은 Some(1)이고 없음 Option의 경우 None입니다. 이는 O.FlatMapNullable이 변환 결과를 Option으로 변환하는 방법을 보여줍니다.
위 내용은 Effect-TS 옵션의 매핑 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!