- Angular UI Development with PrimeNG
- Sudheer Jonna Oleg Varaksin
- 152字
- 2021-07-15 17:32:54
Generics
In TypeScript, you can define generic functions, interfaces, and classes like in other programming languages. A generic function has type parameters listed in angle brackets:
function reverseAndMerge<T>(arr1: T[], arr2: T[]): T[] {
return arr1.reverse().concat(arr2.reverse());
}
let arr1: number[] = [1, 2, 3];
let arr2: number[] = [4, 5, 6];
let arr = reverseAndMerge(arr1, arr2);
Such generic functions can be defined with generic interfaces as well. The function signature for reverseAndMerge is compatible with the following generic interface:
interface GenericArrayFn<T> {
(arr1: T[], arr2: T[]): T[];
}
let arr: GenericArrayFn<number> = reverseAndMerge;
Note that the generic type parameter list in angle brackets follows the name of the function and interface. This is also true for classes:
class GenericValue<T> {
constructor(private value: T) { }
increment: (x: T) => T;
decrement: (x: T) => T;
}
let genericValue = new GenericValue<number>(5);
genericValue.increment = function (x) {return ++x;};
genericValue.decrement = function (x) {return --x;};
推薦閱讀
- iOS Game Programming Cookbook
- ASP.NET Core 2 and Vue.js
- PyTorch自然語言處理入門與實戰
- JavaScript+jQuery開發實戰
- C語言程序設計
- Keras深度學習實戰
- Kotlin編程實戰:創建優雅、富于表現力和高性能的JVM與Android應用程序
- BeagleBone Black Cookbook
- Java網絡編程核心技術詳解(視頻微課版)
- Mastering Git
- 3ds Max印象 電視欄目包裝動畫與特效制作
- Practical GIS
- Groovy 2 Cookbook
- After Effects CC案例設計與經典插件(視頻教學版)
- Unity 5 Game Optimization