官术网_书友最值得收藏!

Creating generic functions

Generics are a very useful way of creating flexible classes and functions. They are very similar to those used in C#. It's very useful to be used in more than one place.

We can create generic functions by adding angle brackets after the function names and enclosing datatypes, as in the following example:

function genericFunction<T>( arg: T ): T [] {
let myGenericArray: T[] = [];
myGenericArray.push(arg);
return myGenericArray;
}

Note that the t inside the angle brackets (<t>) means that genericFunction() is of the generic type.

Let's see this in practice:

  1. In your code editor, create a new file called generics.ts, and add the following code:
function genericFunction<T>( arg: T ): T [] {
let myGenericArray: T[] = [];
myGenericArray.push(arg);
return myGenericArray;
}
let stringFromGenericFunction = genericFunction<string>("Some string goes here");
console.log(stringFromGenericFunction[0]);
let numberFromGenericFunction = genericFunction(190);
console.log(numberFromGenericFunction[0]);

Let's see what happens with our generic function.

  1. Go back to your Terminal and type the following command:
tsc generics.ts
  1. Now, let's execute the file with the following command:
node generics.js

We will see the following result:

Some string goes here
190

Note that the compiler is able to identify the datatype that we are passing as the function argument. In the first case, we explicitly pass the argument as a string, and in the second case, we pass nothing.

Although the compiler is able to identify the type of argument that we are using, it is important to always determine what kind of data we are going to pass. For example:

let numberFromGenericFunction = genericFunction<number>(190);
console.log(numberFromGenericFunction[0]);
主站蜘蛛池模板: 樟树市| 樟树市| 平阳县| 烟台市| 门源| 二连浩特市| 砀山县| 子洲县| 绥阳县| 迁安市| 宁蒗| 平陆县| 长兴县| 南乐县| 扶沟县| 海兴县| 安庆市| 兴和县| 高台县| 德昌县| 垣曲县| 泊头市| 温宿县| 巴中市| 沾化县| 荔波县| 宜都市| 合山市| 措勤县| 弋阳县| 荣成市| 平湖市| 烟台市| 固镇县| 长乐市| 隆尧县| 大丰市| 馆陶县| 芷江| 车险| 英超|