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

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]);
主站蜘蛛池模板: 漳平市| 广河县| 资中县| 巴楚县| 梓潼县| 雅安市| 祁东县| 衡山县| 永济市| 晋宁县| 亳州市| 河北省| 罗平县| 饶河县| 潼南县| 都匀市| 蚌埠市| 黔东| 清河县| 酒泉市| 南京市| 普宁市| 棋牌| 永康市| 鲁山县| 大渡口区| 兴隆县| 门头沟区| 沙雅县| 禄丰县| 凉城县| 淳化县| 南溪县| 广东省| 舞阳县| 金门县| 芮城县| 金沙县| 会理县| 龙门县| 张家口市|