Funkcje zwrotne (callbacks) w TypeScript
Dla funkcji zwrotnych (callback) można również określić typ parametrów i typ zwracanej wartości. Spójrz na przykład:
function make(num: number, func: (num: number) => number): number {
return func(num);
}
Wywołajmy naszą funkcję z jedną funkcją zwrotną:
make(3, function(num: number): number {
return num ** 2;
});
A teraz z inną funkcją zwrotną:
make(3, function(num: number): number {
return num ** 3;
});
Powiedz, jaki będzie wynik wykonania następującego kodu:
type Func = (num: number) => number;
function make(arr: number[], func: Func): number[] {
return arr.map(function(elem: number) {
return func(elem);
});
}
let res: number[] = make([1, 2, 3], function(num: number): number {
return num ** 2;
});
console.log(res);
Znajdź i popraw błędy popełnione w następującym kodzie:
type Func = (num: number) => number;
function make(arr: number, func: Func): number {
let sum = 0;
for (let elem of arr) {
sum += func(elem);
}
return sum;
}
let res: number[] = make([1, 2, 3], function(num): string {
return num ** 2;
});
console.log(res);