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></type>
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></type>
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></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></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") }In addition to the above mentioned, there are other utility types that can help us write cleaner code. A link to the TypeScript documentation on utility types can be found here.
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!

The main difference between Python and JavaScript is the type system and application scenarios. 1. Python uses dynamic types, suitable for scientific computing and data analysis. 2. JavaScript adopts weak types and is widely used in front-end and full-stack development. The two have their own advantages in asynchronous programming and performance optimization, and should be decided according to project requirements when choosing.

Whether to choose Python or JavaScript depends on the project type: 1) Choose Python for data science and automation tasks; 2) Choose JavaScript for front-end and full-stack development. Python is favored for its powerful library in data processing and automation, while JavaScript is indispensable for its advantages in web interaction and full-stack development.

Python and JavaScript each have their own advantages, and the choice depends on project needs and personal preferences. 1. Python is easy to learn, with concise syntax, suitable for data science and back-end development, but has a slow execution speed. 2. JavaScript is everywhere in front-end development and has strong asynchronous programming capabilities. Node.js makes it suitable for full-stack development, but the syntax may be complex and error-prone.

JavaScriptisnotbuiltonCorC ;it'saninterpretedlanguagethatrunsonenginesoftenwritteninC .1)JavaScriptwasdesignedasalightweight,interpretedlanguageforwebbrowsers.2)EnginesevolvedfromsimpleinterpreterstoJITcompilers,typicallyinC ,improvingperformance.

JavaScript can be used for front-end and back-end development. The front-end enhances the user experience through DOM operations, and the back-end handles server tasks through Node.js. 1. Front-end example: Change the content of the web page text. 2. Backend example: Create a Node.js server.

Choosing Python or JavaScript should be based on career development, learning curve and ecosystem: 1) Career development: Python is suitable for data science and back-end development, while JavaScript is suitable for front-end and full-stack development. 2) Learning curve: Python syntax is concise and suitable for beginners; JavaScript syntax is flexible. 3) Ecosystem: Python has rich scientific computing libraries, and JavaScript has a powerful front-end framework.

The power of the JavaScript framework lies in simplifying development, improving user experience and application performance. When choosing a framework, consider: 1. Project size and complexity, 2. Team experience, 3. Ecosystem and community support.

Introduction I know you may find it strange, what exactly does JavaScript, C and browser have to do? They seem to be unrelated, but in fact, they play a very important role in modern web development. Today we will discuss the close connection between these three. Through this article, you will learn how JavaScript runs in the browser, the role of C in the browser engine, and how they work together to drive rendering and interaction of web pages. We all know the relationship between JavaScript and browser. JavaScript is the core language of front-end development. It runs directly in the browser, making web pages vivid and interesting. Have you ever wondered why JavaScr


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

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Dreamweaver Mac version
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

WebStorm Mac version
Useful JavaScript development tools

Zend Studio 13.0.1
Powerful PHP integrated development environment
