w3resource

TypeScript type aliases for improved readability

TypeScript Basic: Exercise-7 with Solution

Write a TypeScript program that creates type aliases for complex data types such as objects or custom types. Use them to define variables and explain how they improve code readability.

Sample Solution:

TypeScript Code:

 // Define a type alias for a user object
type Student = {
  id: number;
  studentname: string;
  email: string;
};

// Define a type alias for a point in 2D space
type Point = {
  x: number;
  y: number;
};

// Create variables using the type aliases
const student1: Student = {
  id: 1,
  studentname: "ginny_millaray",
  email: "[email protected]",
};

const student2: Student = {
  id: 2,
  studentname: "endika_keeva",
  email: "[email protected]",
};

const originPoint: Point = {
  x: 0,
  y: 0,
};

// Functions that use the type aliases
function printStudentInfo(student: Student) {
  console.log(`Student ID: ${student.id}`);
  console.log(`Studentname: ${student.studentname}`);
  console.log(`Email: ${student.email}`);
}

function calculateDistance(point1: Point, point2: Point): number {
  const dx = point1.x - point2.x;
  const dy = point1.y - point2.y;
  return Math.sqrt(dx * dx + dy * dy);
}

// Using the type aliases to improve code readability
console.log("Student 1:");
printStudentInfo(student1);

console.log("\nStudent 2:");
printStudentInfo(student2);

console.log("\nDistance from origin:");
console.log(calculateDistance(originPoint, { x: 3, y: 4 }));

Explanations:

In the exercise above -

  • First, we define two type aliases: 'Student' and 'Point'. 'Student' represents a student object with 'id', 'studentname', and 'email' properties, and 'Point' represents a point in 2D space with x and y coordinates.
  • We create variables 'student', 'student2', and 'origin' using these type aliases. The type annotations make it clear what kind of data each variable should hold.
  • We define functions :printStudentInfo()" and "calculateDistance()" that accept parameters with the corresponding type aliases, improving code readability and ensuring that the expected data structure is passed as an argument.
  • Finally, we use the type aliases to improve code readability when calling these functions and working with the variables.

Output:

"Student 1:"
"Student ID: 1"
"Studentname: ginny_millaray"
"Email: [email protected]"
 
Student 2:"
"Student ID: 2"
"Studentname: endika_keeva"
"Email: [email protected]"
 
Distance from origin:"
5

TypeScript Editor:

See the Pen TypeScript by w3resource (@w3resource) on CodePen.


Previous: TypeScript type conversion example.
Next: TypeScript array operations: Add, remove, iterate.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Become a Patron!

Follow us on Facebook and Twitter for latest update.

It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.

https://w3resource.com/typescript-exercises/typescript-basic-exercise-7.php