- Expert Angular
- Mathieu Nayrolles Rajesh Gunasundaram Sridhar Rao
- 237字
- 2021-07-15 17:05:33
Generics
Generics are very useful for developing reusable components that can work against any data type. So, the client that consumes this component will decide what type of data it should act upon. Let's create a simple function that returns whatever data is passed to it:
function returnNumberReceived(arg: number): number { return arg; }
unction returnStringReceived(arg: string): string { return arg; }
As you can see, we need individual methods to process each data type. We can implement them in a single function using the any data type, as follows:
function returnAnythingReceived (arg: any): any { return arg; }
This is similar to generics. However, we don't have control over the return type. If we pass a number and we can't predict whether the number will be returned or not by the function, the return type can be of any type.
Generics offers a special variable of type T. Applying this type to the function as follows enables the client to pass the data type they would like this function to process:
function returnWhatReceived<T>(arg: T): T { return arg; }
So, the client can call this function for various data types as follows:
var stringOutput = returnWhatReceived<string>("return this"); // type of output will be 'string' var numberOutput = returnWhatReceived<number>(101); // type of output will be number
- 現代C++編程:從入門到實踐
- Java異步編程實戰
- GraphQL學習指南
- Mastering RStudio:Develop,Communicate,and Collaborate with R
- Go語言精進之路:從新手到高手的編程思想、方法和技巧(2)
- Bootstrap for Rails
- C指針原理揭秘:基于底層實現機制
- Mastering JavaScript
- Python應用與實戰
- Python物理建模初學者指南(第2版)
- C++17 By Example
- Mastering ArcGIS Server Development with JavaScript
- 零基礎PHP從入門到精通
- Node.js進階之路
- ReactJS Blueprints