TypeScript
функции
Поиск…
замечания
Необязательные и стандартные параметры
Дополнительные параметры
В TypeScript каждый параметр считается требуемым функцией. Вы можете добавить ? в конце имени параметра, чтобы установить его как необязательный.
Например, параметр lastName
этой функции является необязательным:
function buildName(firstName: string, lastName?: string) {
// ...
}
Необязательные параметры должны появляться после всех необязательных параметров:
function buildName(firstName?: string, lastName: string) // Invalid
Параметры по умолчанию
Если пользователь проходит undefined
или не указывает аргумент, ему будет присвоено значение по умолчанию. Они называются параметрами, инициализированными по умолчанию .
Например, «Смит» является значением по умолчанию для параметра lastName
.
function buildName(firstName: string, lastName = "Smith") {
// ...
}
buildName('foo', 'bar'); // firstName == 'foo', lastName == 'bar'
buildName('foo'); // firstName == 'foo', lastName == 'Smith'
buildName('foo', undefined); // firstName == 'foo', lastName == 'Smith'
Типы функций
Именованные функции
function multiply(a, b) {
return a * b;
}
Анонимные функции
let multiply = function(a, b) { return a * b; };
Функции Lambda / arrow
let multiply = (a, b) => { return a * b; };
Функция как параметр
Предположим, что мы хотим получить функцию как параметр, мы можем сделать это следующим образом:
function foo(otherFunc: Function): void {
...
}
Если мы хотим получить конструктор в качестве параметра:
function foo(constructorFunc: { new() }) {
new constructorFunc();
}
function foo(constructorWithParamsFunc: { new(num: number) }) {
new constructorWithParamsFunc(1);
}
Или, чтобы упростить чтение, мы можем определить интерфейс, описывающий конструктор:
interface IConstructor {
new();
}
function foo(contructorFunc: IConstructor) {
new constructorFunc();
}
Или с параметрами:
interface INumberConstructor {
new(num: number);
}
function foo(contructorFunc: INumberConstructor) {
new contructorFunc(1);
}
Даже с дженериками:
interface ITConstructor<T, U> {
new(item: T): U;
}
function foo<T, U>(contructorFunc: ITConstructor<T, U>, item: T): U {
return new contructorFunc(item);
}
Если мы хотим получить простую функцию, а не конструктор, это почти то же самое:
function foo(func: { (): void }) {
func();
}
function foo(constructorWithParamsFunc: { (num: number): void }) {
new constructorWithParamsFunc(1);
}
Или, чтобы упростить чтение, мы можем определить интерфейс, описывающий функцию:
interface IFunction {
(): void;
}
function foo(func: IFunction ) {
func();
}
Или с параметрами:
interface INumberFunction {
(num: number): string;
}
function foo(func: INumberFunction ) {
func(1);
}
Даже с дженериками:
interface ITFunc<T, U> {
(item: T): U;
}
function foo<T, U>(contructorFunc: ITFunc<T, U>, item: T): U {
return func(item);
}
Функции с типами соединений
Функция TypeScript может принимать параметры нескольких предопределенных типов с использованием типов union.
function whatTime(hour:number|string, minute:number|string):string{
return hour+':'+minute;
}
whatTime(1,30) //'1:30'
whatTime('1',30) //'1:30'
whatTime(1,'30') //'1:30'
whatTime('1','30') //'1:30'
Typcript рассматривает эти параметры как один тип, который является объединением других типов, поэтому ваша функция должна иметь возможность обрабатывать параметры любого типа, который находится в объединении.
function addTen(start:number|string):number{
if(typeof number === 'string'){
return parseInt(number)+10;
}else{
else return number+10;
}
}