- 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;};
推薦閱讀
- 深度實踐OpenStack:基于Python的OpenStack組件開發
- CockroachDB權威指南
- Python數據分析入門與實戰
- JavaScript:Functional Programming for JavaScript Developers
- Learning RxJava
- Scala Design Patterns
- R語言游戲數據分析與挖掘
- Learning Neo4j 3.x(Second Edition)
- The Complete Coding Interview Guide in Java
- Unity 2018 Shaders and Effects Cookbook
- C語言程序設計
- Python語言實用教程
- Julia for Data Science
- 深度實踐KVM:核心技術、管理運維、性能優化與項目實施
- 算法超簡單:趣味游戲帶你輕松入門與實踐