
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