Understanding Functions in TypeScript

Understanding Functions in TypeScript

13 Dec 2024
Intermediate
6.68K Views
16 min read
Learn with an interactive course and practical hands-on labs

TypeScript Programming Course

Functions in TypeScript

Functions in typescript are an integral part of any programming language and are equally important. Consider a function to be a reusable chunk of code that carries out a given activity. TypeScript allows you to define functions in a way that extends the usual JavaScript technique by including type annotations, which assist ensure that the correct kinds of values are utilized.

So In this TypeScript Tutorial, We will see the different types of Functions in typescript including their syntaxes and examples.

What are the Functions in TypeScript

  • Here, Functions in TypeScript are reusable code blocks that execute specific tasks.
  • You can define a function using the 'function' keyword, and TypeScript lets you specify parameter types and return types for added type safety.
  • This means that if a function expects a number as a parameter, TypeScript will enforce it, allowing you to catch mistakes during development.
  • TypeScript also supports features such as optional arguments, default parameters, and rest parameters, making it easier to write versatile and powerful functions for your applications.

Basic Function Syntax

function greet(name: string): string {
  return `Hello, ${name}!`;
}
console.log(greet("Welcome to Scholarhat..!"));

Output

Hello, Welcome to Scholarhat..!!

In this example:

  • name: string specifies that the name parameter must be a string.
  • : string after the parameter list indicates that the function returns a string.

Function Types

TypeScript allows you to define various aspects of functions using type annotations, enhancing code reliability and readability.

1. Typed Parameters and Return Types

By specifying types for function parameters and return values, TypeScript ensures that functions are used correctly.

Example

function add(a: number, b: number): number {
  return a + b;
}
console.log(add(5, 3)); 

Output

8

2. Optional and Default Parameters

1. Optional Parameters

Optional parameters are denoted by a ? after the parameter name. They may or may not be provided when the function is called.

Example

function buildName(firstName: string, lastName?: string): string {
  if (lastName) {
    return `${firstName} ${lastName}`;
  } else {
    return firstName;
  }
}

console.log(buildName("John")); 
console.log(buildName("John", "Doe"));

Output

John
John Doe

2. Default Parameters

Default parameters allow you to specify a default value for a parameter if none is provided.

Example

function greet(name: string, greeting: string = "Hello"): string {
  return `${greeting}, ${name}!`;
}
console.log(greet("Welcome to Scholarhat..!")); 
console.log(greet("Welcome to Scholarhat..!", "Hi"));

Output

Hello, Welcome to Scholarhat..!!
Hi, Welcome to Scholarhat..!!

3. Rest Parameters

Rest parameters allow functions to accept an indefinite number of arguments as an array.

Example

function sum(...numbers: number[]): number {
  return numbers.reduce((acc, curr) => acc + curr, 0);
}
console.log(sum(1, 2, 3, 4)); // Output: 10

Output

10

Function Signatures

Function signatures define the type of functions, specifying the parameter types and return type without providing the actual implementation. They are particularly useful when defining interfaces or type aliases for functions.

1. Using Interfaces

Example

interface StringGenerator {
  (length: number): string;
}
const generateString: StringGenerator = (length: number): string => {
  return "a".repeat(length);
};
console.log(generateString(5));  

Output

aaaaa

2. Using Type Aliases

Example

type MathOperation = (x: number, y: number) => number;
const multiply: MathOperation = (a, b) => a * b;
console.log(multiply(4, 5)); // Output: 20   

Output

20

Function Overloading

Function overloading allows you to define multiple signatures for a single function, enabling different ways to call it based on the number or types of parameters.

Example of Function Overloading

function combine(a: string, b: string): string;
function combine(a: number, b: number): number;
function combine(a: any, b: any): any {
  if (typeof a === "string" && typeof b === "string") {
    return a + b;
  } else if (typeof a === "number" && typeof b === "number") {
    return a + b;
  }
}
console.log(combine("Hello, ", "World!")); // Output: Hello, World!
console.log(combine(10, 20)); // Output: 30   

Output

Hello, World!
30
Read More - Typescript Interview Questions And Answers

The this Keyword in Functions

Handling the this keyword in TypeScript functions can be tricky, especially when dealing with different contexts. TypeScript provides type annotations to specify the type of this within functions.

Typing this

interface Point {
  x: number;
  y: number;
  move(this: Point, dx: number, dy: number): void;
}
const point: Point = {
  x: 0,
  y: 0,
  move(dx: number, dy: number) {
    this.x += dx;
    this.y += dy;
  },
};
point.move(5, 10);
console.log(point);     

Output

{ x: 5, y: 10, move: [Function: move] }

Arrow Functions

Arrow functions offer a concise syntax and lexically bind the this keyword, making them suitable for scenarios where you want to maintain the context of this.

Example of Arrow Functions

const numbers = [1, 2, 3, 4, 5];
const doubled = numbers.map((num) => num * 2);
console.log(doubled); // Output: [2, 4, 6, 8, 10]  

Output

[ 2, 4, 6, 8, 10 ]

Higher-Order Functions

Higher-order functions are functions that take other functions as arguments or return functions as their results. TypeScript's type annotations enhance the reliability of higher-order functions by ensuring that the passed functions adhere to expected signatures.

Example of a Higher-Order Function

function operate(a: number, b: number, operation: (x: number, y: number) => number): number {
  return operation(a, b);
}
const add = (x: number, y: number): number => x + y;
const subtract = (x: number, y: number): number => x - y;
console.log(operate(10, 5, add)); // Output: 15
console.log(operate(10, 5, subtract)); // Output: 5   

Output

15
5

Practical Examples

1. Simple Function Example

function greet(name: string): string {
  return `Hello, ${name}!`;
}
console.log(greet("Bob")); // Output: Hello, Bob!  

Output

Hello, Bob!

2. Function with Optional and Default Parameters

function createUser(username: string, age?: number, isAdmin: boolean = false): string {
  return `User: ${username}, Age: ${age ?? "N/A"}, Admin: ${isAdmin}`;
}

console.log(createUser("Welcome to Scholarhat..!")); // Output: User: Welcome to Scholarhat..!, Age: N/A, Admin: false
console.log(createUser("Bob", 30, true));  // Output: User: Bob, Age: 30, Admin: true    

Output

User: Welcome to Scholarhat..!, Age: N/A, Admin: false
User: Bob, Age: 30, Admin: true

3. Function Overloading Example

function merge(a: string, b: string): string;
function merge(a: number, b: number): number;
function merge(a: any, b: any): any {
  if (typeof a === "string" && typeof b === "string") {
    return a + b;
  } else if (typeof a === "number" && typeof b === "number") {
    return a + b;
  }
}
console.log(merge("Hello, ", "World!")); // Output: Hello, World!
console.log(merge(10, 20)); // Output: 30

Output

Hello, World!
30
Conclusion

Finally, TypeScript functions are effective tools for improving code organization and reusability while also ensuring type safety. TypeScript allows developers to specify parameter and return types, which helps detect potential issues early and leads to more robust programs. The addition of optional and default parameters increases flexibility, making it easier to handle a variety of use cases. Overall, learning TypeScript functions is critical for producing efficient and maintainable code in your projects.

FAQs

 A function declaration defines a named function that is hoisted, meaning it can be called before it is defined in the code. A function expression, on the other hand, creates a function that can be anonymous or assigned to a variable, and it is not hoisted, so it can only be called after its definition. 

 You can define optional parameters in TypeScript by adding a question mark (?) after the parameter name in the function declaration. For example: function greet(name?: string). This allows you to call the function without providing that parameter, and TypeScript will treat it as undefined if it’s omitted. 

 Yes, TypeScript supports function overloading, which allows you to define multiple function signatures for a single function implementation. You can specify different parameter types and return types for the same function name, and TypeScript will determine which implementation to call based on the arguments provided. 

Take our Typescript skill challenge to evaluate yourself!

In less than 5 minutes, with our skill challenge, you can identify your knowledge gaps and strengths in a given skill.

GET FREE CHALLENGE

Share Article
About Author
Shailendra Chauhan (Microsoft MVP, Founder & CEO at ScholarHat)

Shailendra Chauhan, Founder and CEO of ScholarHat by DotNetTricks, is a renowned expert in System Design, Software Architecture, Azure Cloud, .NET, Angular, React, Node.js, Microservices, DevOps, and Cross-Platform Mobile App Development. His skill set extends into emerging fields like Data Science, Python, Azure AI/ML, and Generative AI, making him a well-rounded expert who bridges traditional development frameworks with cutting-edge advancements. Recognized as a Microsoft Most Valuable Professional (MVP) for an impressive 9 consecutive years (2016–2024), he has consistently demonstrated excellence in delivering impactful solutions and inspiring learners.

Shailendra’s unique, hands-on training programs and bestselling books have empowered thousands of professionals to excel in their careers and crack tough interviews. A visionary leader, he continues to revolutionize technology education with his innovative approach.
Accept cookies & close this