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

[ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ] 2๊ฐœ ์ด์ƒ์˜ ์ œ๋„ค๋ฆญ ์ ์šฉํ•ด๋ณด๊ธฐ(์ถ”๋ก , ๋ช…์‹œ, ํ”„๋กœ๋ฏธ์Šค ์ œ๋„ค๋ฆญ๊นŒ์ง€)

Rainbow๐ŸŒˆCoder 2022. 4. 21. 12:28
728x90

2๊ฐœ ์ด์ƒ์˜ ์ œ๋„ค๋ฆญ ์ ์šฉํ•ด๋ณด๊ธฐ

 

์ดˆ์•ˆ

function map(array: unknown[], f: (item: unknown) => unknown): unknown[] {
  let result = [];
  for (let i = 0; i < array.length; i++) {
    result[i] = f(array[i]);
  }
  return result;
}

 

์ ์šฉ ํ›„

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;
}

: ์ธ์ˆ˜ ๋ฐฐ์—ด ๋ฉค๋ฒ„์˜ ํƒ€์ž…์„ ๋Œ€๋ณ€ํ•˜๋Š” T, ๋ฐ˜ํ™˜ ๋ฐฐ์—ด ๋ฉค๋ฒ„ ํƒ€์ž…์„ ๋Œ€๋ณ€ํ•˜๋Š” U, ์ด๋ ‡๊ฒŒ ๋‘๊ฐ€์ง€ ์ œ๋„ค๋ฆญ ํƒ€์ž…์ด ํ•„์š”ํ•˜๋‹ค.

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

 

.map์€ ์›๋ž˜๋„ ์‚ฌ์‹ค์ƒ T์˜ ๋ฐฐ์—ด์„ U์˜ ๋ฐฐ์—ด๋กœ ๋งคํ•‘ํ•œ๋‹ค

 

ํ˜ธ์ถœ๊ฒฐ๊ณผ

function map<T>(array: T[], f: (item: T) => T): T[] {
  let result = [];
  for (let i = 0; i < array.length; i++) {
    result[i] = f(array[i]);
  }
  return result;
}
console.log(map(["์‚ฌ๊ณผ", "๋”ธ๊ธฐ", "์ฒญํฌ๋„"], (_) => "๊ณผ์ผ")); //[ '๊ณผ์ผ', '๊ณผ์ผ', '๊ณผ์ผ' ]

 

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(
    [{ ๊ณผ์ผ: "๋”ธ๊ธฐ" }, { ๊ณผ์ผ: "์ฒญํฌ๋„" }, { ๊ณผ์ผ: "์‚ฌ๊ณผ" }],
    (_) => _.๊ณผ์ผ === "์‚ฌ๊ณผ"
  )
); //[ false, false, true ]

1๊ฐœ๋Š” ๋” ์‰ฝ๋‹ค

 

์ดˆ์•ˆ

function filter(array: unknown[], f: (item: unknown) => boolean): unknown[] {
  let result = [];
  // tslint:disable-next-line: prefer-for-of
  for (let i = 0; i < array.length; i++) {
    let item = array[i];
    if (f(item)) {
      result.push(item);
    }
  }
  return result;
}

 

์ ์šฉ ํ›„

function filter<T>(array: T[], f: (item: T) => boolean): T[] {
  let result = [];
  // tslint:disable-next-line: prefer-for-of
  for (let i = 0; i < array.length; i++) {
    let item = array[i];
    if (f(item)) {
      result.push(item);
    }
  }
  return result;
}

let names = [{ ์ด๋ฆ„: "smith" }, { ์ด๋ฆ„: "kate" }, { ์ด๋ฆ„: "max" }];

//1. T๋Š” number๋กœ ํ•œ์ •๋จ
console.log(filter([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], (_) => _ > 5)); //[ 6, 7, 8, 9, 10 ]

//2. T๋Š” string์œผ๋กœ ํ•œ์ •๋จ
console.log(filter(["a", "b", "ab", "b", "c"], (_) => _ !== "b")); //[ 'a', 'ab', 'c' ]

//3. T๋Š” {์ด๋ฆ„:string}์œผ๋กœ ํ•œ์ •๋จ
console.log(filter(names, (_) => _.์ด๋ฆ„.endsWith("h"))); //[ { '์ด๋ฆ„': 'smith' } ]

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

 

์ถ”๋ก 

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(["๋”ธ๊ธฐ", "์ฒญํฌ๋„", "์‚ฌ๊ณผ"], (_) => _ === "์‚ฌ๊ณผ")); //[ 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<string, boolean>(["๋”ธ๊ธฐ", "์ฒญํฌ๋„", "์‚ฌ๊ณผ"], (_) => _ === "์‚ฌ๊ณผ")
); //[ false, false, true ]

ํƒ€์ž… ์ธ์ˆ˜ ํ•˜๋‚˜๋งŒ ์„ค์ •ํ•˜๋ฉด ๊ท€์‹ ๊ฐ™์ด ๋‘ ๊ฐœ ํ•„์š”ํ•˜๋‹ค๊ณ  ์•„์šฐ์„ฑ
ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ์ถ”๋ก ๋œ ์ œ๋„ค๋ฆญ ํƒ€์ž…์„ ๋ช…์‹œ์ ์œผ๋กœ ํ•œ์ •ํ•œ ์ œ๋„ค๋ฆญ์— ํ• ๋‹นํ•  ์ˆ˜ ์žˆ๋Š”์ง€ ํ™•์ธํ•˜๊ณ  ํ• ๋‹นํ•  ์ˆ˜ ์—†์œผ๋ฉด ๊ท€์‹ ๊ฐ™์ด ์—๋Ÿฌ๋ฅผ ๋„์šด๋‹ค.

<์ค‘๊ฐ„์š”์•ฝ>

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

function map<string> (     // ์—๋Ÿฌ TS2558: ๋‘ ๊ฐœ์˜ ํƒ€์ž… ์ธ์ˆ˜๊ฐ€ ํ•„์š”ํ•œ๋ฐ ํ•œ ๊ฐœ๋งŒ ์ „๋‹ฌ๋จ
  // ...
)

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>(["๋”ธ๊ธฐ", "์ฒญํฌ๋„", "์‚ฌ๊ณผ"], (_) => _ === "์‚ฌ๊ณผ")
); //[ 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<string, number>(["๋”ธ๊ธฐ", "์ฒญํฌ๋„", "์‚ฌ๊ณผ"], (_) => _ === "์‚ฌ๊ณผ")
//'boolean'ํ˜•์‹์€ 'number'ํ˜•์‹์— ํ• ๋‹นํ•  ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค.         ~~~~~~~~~~
); //[ false, false, true ]

 

 

 

 

์ œ๋„ค๋ฆญ ์—ฌ๋Ÿฌ๊ฐ€์ง€ ์Šคํƒ€์ผ

 

1. T์˜ ๋ฒ”์œ„๋ฅผ ๊ฐœ๋ณ„ ์‹œ๊ทธ๋‹ˆ์ฒ˜๋กœ ํ•œ์ •ํ•œ ์ „์ฒด ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜
//ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” filterํƒ€์ž…์˜ ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•  ๋•Œ ์ด ์‹œ๊ทธ๋‹ˆ์ฒ˜์˜ T๋ฅผ ๊ตฌ์ฒด ํƒ€์ž…์œผ๋กœ ํ•œ์ •ํ•œ๋‹ค
//๊ฐ๊ฐ์˜ filterํ˜ธ์ถœ์€ ์ž์‹ ๋งŒ์˜ Tํ•œ์ • ๊ฐ’์„ ๊ฐ–๋Š”๋‹ค

type Filter = {
  <T>(array: T[], f: (item: T) => boolean): T[]
}

let filter: Filter = (array, f) // ....

2. T์˜ ๋ฒ”์œ„๋ฅผ ๋ชจ๋“  ์‹œ๊ทธ๋‹ˆ์ฒ˜๋กœ ํ•œ์ •ํ•œ ์ „์ฒด ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜
//T๋ฅผ Filter ํƒ€์ž…์˜ ์ผ๋ถ€๋กœ ์„ ์–ธํ–ˆ์œผ๋ฏ€๋กœ ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” Filter ํƒ€์ž…์˜ ํ•จ์ˆ˜๋ฅผ ์„ ์–ธํ•  ๋•Œ T๋ฅผ ํ•œ์ •ํ•œ๋‹ค. 
type Filter<T> = {
  (array: T[], f: (item: T) => boolean): T[]
}

let filter: Filter<number> = // ....

3. 1์˜ ๋‹จ์ถ• ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜
type Filter = <T>(array: T[], f: (item: T) => boolean) => T[]
let filter: Filter = // ...

4. 2์˜ ๋‹จ์ถ• ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜
type Filter<T> = <T>(array: T[], f: (item: T) => boolean) => T[]
let filter: Filter<string> = // ...

5. T๋ฅผ ์‹œ๊ทธ๋‹ˆ์ฒ˜ ๋ฒ”์œ„๋กœ ํ•œ์ •ํ•œ, ์ด๋ฆ„์„ ๊ฐ–๋Š” ํ•จ์ˆ˜ ํ˜ธ์ถœ ์‹œ๊ทธ๋‹ˆ์ฒ˜
//ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” filter ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•  ๋•Œ ์ด ์‹œ๊ทธ๋‹ˆ์ฒ˜์˜ T๋ฅผ ๊ตฌ์ฒด ํƒ€์ž…์œผ๋กœ ํ•œ์ •ํ•œ๋‹ค
//๊ฐ๊ฐ์˜ filterํ˜ธ์ถœ์€ ์ž์‹ ๋งŒ์˜ Tํ•œ์ • ๊ฐ’์„ ๊ฐ–๋Š”๋‹ค
function filter<T>(array: T[], f: (item: T) => boolean): T[] {
  let result = [];
  // tslint:disable-next-line: prefer-for-of
  for (let i = 0; i < array.length; i++) {
    let item = array[i];
    if (f(item)) {
      result.push(item);
    }
  }
  return result;
}
type Filter<T> = { (array: T[], f: (iter: T) => boolean): T[] };

let names = [{ ์ด๋ฆ„: "smith" }, { ์ด๋ฆ„: "kate" }, { ์ด๋ฆ„: "max" }];

//1. T๋Š” number๋กœ ํ•œ์ •๋จ
console.log(filter([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], (_) => _ > 5)); //[ 6, 7, 8, 9, 10 ]

//2. T๋Š” string์œผ๋กœ ํ•œ์ •๋จ
console.log(filter(["a", "b", "ab", "b", "c"], (_) => _ !== "b")); //[ 'a', 'ab', 'c' ]

//3. T๋Š” {์ด๋ฆ„:string}์œผ๋กœ ํ•œ์ •๋จ
console.log(filter(names, (_) => _.์ด๋ฆ„.endsWith("h"))); //[ { '์ด๋ฆ„': 'smith' } ]

 

์ •์„๊ฐ™์€ ๋А๋‚Œ์˜ ์Šคํƒ€์ผ๋ง

//filter์˜ ํƒ€์ž… ์‹œ๊ทธ๋‹ˆ์ฒ˜
type Filter = { <T>(array: T[], f: (iter: T) => boolean): T[] };

let filter: Filter = (array, f) => {
  let result = [];
  // tslint:disable-next-line: prefer-for-of
  for (let i = 0; i < array.length; i++) {
    let item = array[i];
    if (f(item)) {
      result.push(item);
    }
  }
  return result;
};
let names = [{ ์ด๋ฆ„: "smith" }, { ์ด๋ฆ„: "kate" }, { ์ด๋ฆ„: "max" }];

//1. T๋Š” number๋กœ ํ•œ์ •๋จ
console.log(filter([1, 2, 3, 4, 5, 6, 7, 8, 9, 10], (_) => _ > 5)); //[ 6, 7, 8, 9, 10 ]

//2. T๋Š” string์œผ๋กœ ํ•œ์ •๋จ
console.log(filter(["a", "b", "ab", "b", "c"], (_) => _ !== "b")); //[ 'a', 'ab', 'c' ]

//3. T๋Š” {์ด๋ฆ„:string}์œผ๋กœ ํ•œ์ •๋จ
console.log(filter(names, (_) => _.์ด๋ฆ„.endsWith("h"))); //[ { '์ด๋ฆ„': 'smith' } ]

 

<์ด์ƒํ•œ ์ƒํ™ฉ>

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

let promise = new Promise((resolve) => resolve(45));

promise.then((result) => result * 4);
                       //~~~~~~ ๊ฐœ์ฒด๊ฐ€ ์•Œ ์ˆ˜ ์—†๋Š” ํ˜•์‹์ž…๋‹ˆ๋‹ค.

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

ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋Š” ์ œ๋„ค๋ฆญ ํ•จ์ˆ˜์˜ ์ธ์ˆ˜์—๋งŒ ์˜์ง€ํ•˜์—ฌ ์ œ๋„ค๋ฆญ ํƒ€์ž…์„ ์ถ”๋ก ํ•˜๋Š”๋ฐ, ์ธ์ˆ˜๊ฐ€ ์•„๋ฌด ๊ฒƒ๋„ ์—†์œผ๋‹ˆ ๊ธฐ๋ณธ์ ์œผ๋กœ T๋ฅผ ์•Œ ์ˆ˜ ์—†๋‹ค๊ณ  ๋ฐฉ์น˜ํ•˜๋Š” ๊ฒƒ์ด๋‹ค!

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

let promise = new Promise<number>((resolve) => resolve(45));

promise.then((result) => console.log(result * 4)); //180

 

 

728x90