TypeScript/ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] ์ œ๋„ค๋ฆญ ํƒ€์ž… ๋ช…์‹œ ์ฃผ์˜์‚ฌํ•ญ

Rainbow๐ŸŒˆCoder 2022. 4. 26. 14:39
728x90

 

1. ์ œ๋„ค๋ฆญ ํƒ€์ž… ๋ช…์‹œ ์ฃผ์˜์‚ฌํ•ญ

์ œ๋„ค๋ฆญ์˜ ํƒ€์ž…์„ ๋ช…์‹œํ•  ๋•Œ๋Š” ๋ชจ๋“  ํ•„์š”ํ•œ ์ œ๋„ค๋ฆญ ํƒ€์ž…์„ ๋ช…์‹œํ•˜๊ฑฐ๋‚˜ ๋ฐ˜๋Œ€๋กœ ์•„๋ฌด ๊ฒƒ๋„ ๋ช…์‹œํ•ด์„œ๋Š” ์•ˆ ๋œ๋‹ค.

์ธ์ˆ˜ ๋ฐฐ์—ด ๋ฉค๋ฒ„์˜ ํƒ€์ž…์„ ๋Œ€๋ณ€ํ•˜๋Š” T, ๋ฐ˜ํ™˜ ๋ฐฐ์—ด ๋ฉค๋ฒ„ ํƒ€์ž…์„ ๋Œ€๋ณ€ํ•˜๋Š” U ์ด๋ ‡๊ฒŒ ๋‘ ๊ฐ€์ง€ ์ œ๋„ค๋ฆญ ํƒ€์ž…์ด ํ•„์š”ํ•˜๋‹ค. Tํƒ€์ž…์˜ ์š”์†Œ๋ฅผ ํฌํ•จํ•˜๋Š” ๋ฐฐ์—ด์„ ์ „๋‹ฌํ•˜๋ฉด ๋งคํ•‘ ํ•จ์ˆ˜๊ฐ€ T ํƒ€์ž…์˜ ๊ฐ’์„ ๊ฐ€์ง€๊ณ  U ํƒ€์ž…์˜ ๊ฐ’์œผ๋กœ ๋ณ€ํ™˜ํ•œ๋‹ค. ๊ทธ๋ฆฌ๊ณ  ์ตœ์ข…์ ์œผ๋กœ U ํƒ€์ž…์˜ ํ•ญ๋ชฉ์„ ํฌํ•จํ•œ๋А ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

 

์ฆ‰, ์ด๋ ‡๊ฒŒ ์“ฐ๊ฑฐ๋‚˜ ( ํƒ€์ž… ๋ช…์‹œ)

function map<T, U>(array: T[], f: (item: T) => U): U[] {
  let result = [];
  for (let i = 0; i < array.length; i++) {
    result[i] = f(array[i]);
  }
  return result;
}
console.log(map<string, boolean>(["a", "b", "c", "d"], (_) => _ === "a")); //[ false, false, true ]

์ด๋ ‡๊ฒŒ ์จ์•ผ ํ•œ๋‹ค. (ํƒ€์ž… ์ถ”๋ก )

function map<T, U>(array: T[], f: (item: T) => U): U[] {
  let result = [];
  for (let i = 0; i < array.length; i++) {
    result[i] = f(array[i]);
  }
  return result;
}
console.log(map(["a", "b", "c", "d"], (_) => _ === "a")); //[ false, false, true ]

 

 

2. ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ์ œ๋„ค๋ฆญ ํ•จ์ˆ˜๋กœ ์ „๋‹ฌํ•œ ์ธ์ˆ˜์˜ ์ •๋ณด๋ฅผ ์ด์šฉํ•ด ์ œ๋„ค๋ฆญ์˜ ๊ตฌ์ฒด ํƒ€์ž…์„ ์ถ”๋ก ํ•˜๋ฏ€๋กœ ๋•Œ๋กœ๋Š” ์•„๋ž˜์™€ ๊ฐ™์€ ์ƒํ™ฉ์ด ํŽผ์ณ์งˆ ์ˆ˜ ์žˆ๋‹ค.

let promise = new Promise((resolve) => resolve(45));
promise.then((result) => result * 4);
                         ~~~~~~

์œ„์—์„œ ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๊ฐ€ result๋ฅผ {}๋กœ ์ถ”๋ก ํ•œ ๊ฒƒ์€

ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ์— ์ถฉ๋ถ„ํ•œ ์ •๋ณด๋ฅผ ์ œ๊ณตํ•˜์ง€ ์•Š์•˜๊ธฐ ๋•Œ๋ฌธ์ด๋‹ค.

ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ์ œ๋„ค๋ฆญ ํ•จ์ˆ˜์˜ ์ธ์ˆ˜์—๋งŒ ์˜์ง€ํ•˜์—ฌ ์ œ๋„ค๋ฆญ ํƒ€์ž…์„ ์ถ”๋ก ํ•˜๋Š”๋ฐ,

์ธ์ˆ˜๊ฐ€ ์•„๋ฌด ๊ฒƒ๋„ ์—†์œผ๋‹ˆ ๊ธฐ๋ณธ์ ์œผ๋กœ T๋ฅผ {}๋กœ ๊ฐ„์ฃผํ•œ ๊ฒƒ์ด๋‹ค.

 

Promise์˜ ์ œ๋„ค๋ฆญ ํƒ€์ž… ๋งค๊ฐœ๋ณ€์ˆ˜๋ฅผ ๋ช…์‹œํ•ด์„œ ์ด ๋ฌธ์ œ๋ฅผ ํ•ด๊ฒฐํ•  ์ˆ˜ ์žˆ๋‹ค.

let promise = new Promise<number>((resolve) => resolve(45));
promise.then((result) => result * 4);

 

 

 

728x90