This content originally appeared on DEV Community and was authored by Irena Popova 👩🏻💻
TypeScript is a superset of JavaScript that adds static typing to help catch errors during development and make code more predictable. Below are the main syntax elements and concepts you need to understand in TypeScript, along with examples.
Type Annotations
TypeScript allows you to explicitly define the types of variables, function parameters, and return values.
// Variables with types
let isDone: boolean = true;
let count: number = 42;
let name: string = "Irena";
// Arrays
let numbers: number[] = [1, 2, 3];
let names: string[] = ['Alice', 'Bob'];
// Tuple (fixed size and type array)
let person: [string, number] = ['Irena', 30];
// Any (disables type checking)
let unknownValue: any = 'hello';
unknownValue = 42; // valid
Functions
Functions in TypeScript can have type annotations for parameters and return values. Optional and default parameters are also supported
// Function with typed parameters and return value
function add(a: number, b: number): number {
return a + b;
}
// Optional parameter
function greet(name: string, age?: number): string {
return age ? `Hello, ${name}. You are ${age}.` : `Hello, ${name}.`;
}
// Default parameter
function log(message: string = "Default message"): void {
console.log(message);
}
###Interfaces
Interfaces define the shape of objects, ensuring that objects adhere to a particular structure.
interface Person {
name: string;
age: number;
greet(): string;
}
const person1: Person = {
name: 'Irena',
age: 30,
greet: () => `Hello, my name is ${person1.name}`
};
Classes
TypeScript allows you to create classes with properties and methods. It supports object-oriented features like inheritance, access modifiers (public, private, protected), and abstract classes.
class Animal {
// Access modifiers: public, private, protected
public name: string;
private age: number;
constructor(name: string, age: number) {
this.name = name;
this.age = age;
}
public speak(): string {
return `The animal ${this.name} makes a sound.`;
}
private getAge(): number {
return this.age;
}
}
// Inheritance
class Dog extends Animal {
constructor(name: string, age: number) {
super(name, age);
}
public speak(): string {
return `The dog ${this.name} barks.`;
}
}
const dog = new Dog("Buddy", 3);
console.log(dog.speak());
Enums
Enums are used to define a set of named constants.
enum Direction {
Up,
Down,
Left,
Right
}
let move: Direction = Direction.Up;
Generics
Generics allow you to create reusable components that work with any type, providing flexibility and type safety.
function identity<T>(value: T): T {
return value;
}
let result = identity<string>("hello"); // 'hello'
let numberResult = identity<number>(42); // 42
// Generic interfaces
interface Box<T> {
content: T;
}
const stringBox: Box<string> = { content: "A string" };
const numberBox: Box<number> = { content: 100 };
Union & Intersection Types
Union types allow a variable to be one of several types, while intersection types combine multiple types into one.
// Union Type (value can be string or number)
let value: string | number = "Hello";
value = 42;
// Intersection Type (combine multiple types)
interface ErrorHandling {
success: boolean;
error?: { message: string };
}
interface Data {
data: { name: string };
}
type ApiResponse = ErrorHandling & Data;
const response: ApiResponse = {
success: true,
data: { name: "Irena" }
};
Type Aliases
Type aliases allow you to give a name to a type, which can be a primitive, union, or a more complex structure.
type StringOrNumber = string | number;
let result1: StringOrNumber = "Hello";
let result2: StringOrNumber = 42;
Type Assertions
Type assertions are used to tell the compiler to treat a value as a specific type
let someValue: any = "this is a string";
let strLength: number = (someValue as string).length;
Modules
TypeScript uses the ES6 module syntax to organize code. You can export and import modules.
// person.ts
export interface Person {
name: string;
age: number;
}
// main.ts
import { Person } from './person';
const person: Person = { name: 'Irena', age: 30 };
Key Takeaways:
Type Annotations: Specify the type of variables, function parameters, and return values.
Interfaces and Types: Define the structure of objects.
Generics: Allow functions and classes to work with any type.
Access Modifiers: Control visibility of class properties and methods (public, private, protected).
Modules: Organize your code by exporting and importing across different files.
TypeScript helps prevent runtime errors by providing early checks, making the development process more robust!
This content originally appeared on DEV Community and was authored by Irena Popova 👩🏻💻
Irena Popova 👩🏻💻 | Sciencx (2024-10-23T06:08:30+00:00) Typescript. Retrieved from https://www.scien.cx/2024/10/23/typescript-4/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.