A brief discussion on 7 methods worth knowing in TypeScript
This article will share with you 7 methods in TypeScript that you need to know. I hope it will be helpful to you!
#The type system in TypeScript is very powerful. It provides us with type safety. As beloved as type systems are, they can also make our code cluttered and unreadable if we don't plan and design types and interfaces.
Generics
Avoiding code duplication and creating reusable types is an important part of writing concise code. Generics are a feature of TypeScript that allow us to write reusable types. Look at the following example:
type Add<T> = (a: T, b: T) => T const addNumbers: Add<number> = (a, b) => { return a + b } const addStrings: Add<string> = (a, b) => { return a + b }
Put the correct type into the generic type of Add
, which can be used to describe the addition of two numbers or the concatenation of two strings. Instead of writing a type for each function, we only need to do it once with generics. Not only does this save us effort, but it also makes our code cleaner and less error-prone.
Utility types
TypeScript natively provides several useful utility types to help us perform some common type conversions. These utility types are globally available and they all use generics.
The following 7 are the ones I often use.
1. Pick<Type, Keys>
Pick
will select the attribute set Keys from Type to create a New type, Keys can be a string literal or a union of string literals. The value of Keys must be a key of the Type , otherwise the TypeScript compiler will complain. This utility type is particularly useful when you want to create a lighter object by picking certain properties from an object that has many properties.
type User = { name: string age: number address: string occupation: string } type BasicUser = Pick<User, "name" | "age"> // type BasicUser = { // name: string; // age: number; // }
2. Omit<Type, Keys>
Omit
is the opposite of Pick
. Keys
It does not mean which attributes to keep, but the set of attribute keys to omit. This is more useful when we just want to remove certain properties from the object and keep others.
type User = { name: string age: number address: string occupation: string } type BasicUser = Omit<User, "address" | "occupation"> // type BasicUser = { // name: string; // age: number; // }
3. Partial<Type>
Partial
Constructs a type with all its type attributes set is optional. This can be very useful when we are writing update logic for an object.
type User = { name: string age: number address: string occupation: string } type PartialUser = Partial<User> // type PartialUser = { // name?: string; // age?: number; // address?: string; // occupation?: string; // }
4. Required<Type>
##Required is the opposite of
Partial. It constructs a type where all properties are required. It can be used to ensure that no optional properties are present in a type.
type PartialUser = { name: string age: number address?: string occupation?: string } type User = Required<PartialUser> // type User = { // name: string; // age: number; // address: string; // occupation: string; // }
5. Readonly
Readonly Constructs a type with all properties of its type set is read-only. Reassigning a new value TS will result in an error.
type User = { name: string age: number address: string occupation: string } type ReadOnlyUser = Readonly<User> const user: ReadOnlyUser = { name: "小智", age: 24, address: "厦门", occupation: "大迁世界" } user.name = "王大冶" // Cannot assign to 'name' because it is a read-only property.
6. ReturnType
ReturnType Constructs a type from the return type of a function type. It is very useful when we deal with function types from external libraries and want to build custom types based on them.
import axios from 'axios' type Response = ReturnType<typeof axios> function callAPI(): Response{ return axios("url") }
https://www.typescriptlang.org/docs/handbook/utility-types.htmlUtility types are a very useful feature provided by TypeScript. Developers should take advantage of them to avoid hardcoding types. Looking better than your colleagues? Here’s what you need to know!
This article is reprinted at: https://segmentfault.com/a/1190000040574488For more programming-related knowledge, please visit:
Introduction to Programming ! !
The above is the detailed content of A brief discussion on 7 methods worth knowing in TypeScript. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Generic functions in Go solve the problem of variadic types: generic functions allow type parameters to be specified at runtime. This makes it possible to write functions that can handle parameters of different types. For example, the Max function is a generic function that accepts two comparable parameters and returns the larger value. By using generic functions, we can write more flexible and general code that can handle different types of parameters.

Application scenarios of generics in Go: Collection operations: Create collection operations suitable for any type, such as filtering. Data Structures: Write general-purpose data structures such as queues, stacks, and maps to store and manipulate various types of data. Algorithms: Write general-purpose algorithms such as sorting, search, and reduction that can handle different types of data.

Java function generics allow setting upper and lower bounds. Extends specifies that the data type accepted or returned by a function must be a subtype of the specified type, e.g. The lower bound (super) specifies that the data type accepted or returned by a function must be a supertype of the specified type, e.g. The use of generics improves code reusability and security.

The impact of generics on Go function signatures and parameters includes: Type parameters: Function signatures can contain type parameters, specifying the types that the function can use. Type constraints: Type parameters can have constraints that specify conditions that they must satisfy. Parameter type inference: The compiler can infer the type of unspecified type parameters. Specifying types: Parameter types can be explicitly specified to call generic functions. This increases code reusability and flexibility, allowing you to write functions and types that can be used with multiple types.

Limitations of Go generic functions: only type parameters are supported, value parameters are not supported. Function recursion is not supported. Type parameters cannot be specified explicitly, they are inferred by the compiler.

The combination of enumeration types and generics in Java: When declaring an enumeration with generics, you need to add angle brackets, and T is the type parameter. When creating a generic class, you also need to add angle brackets, T is a type parameter that can store any type. This combination improves code flexibility, type safety, and simplifies code.

Java generic methods automatically infer type parameters without explicit declaration. Rules include: 1. Use explicit type declarations; 2. Infer a single type; 3. Infer wildcard types; 4. Infer constructor return value types. This simplifies the code, making it easier to write and use generic methods.

In Go, variable parameters can be used for generic functions, allowing the creation of generic functions that accept a variable number of parameters and are suitable for multiple types. For example, you can create a generic function Mode that finds the most frequently occurring element in a given list: Mode accepts a variable number of elements of type T. It counts elements by creating counts for each element. Then it finds the element that appears the most and returns it as mode. In the main function, you can call the Mode function for the list of strings and the list of integers, which will return the string and number with the most occurrences respectively.
