目录
泛型
实用类型
首页 web前端 js教程 浅谈TypeScript中值得了解的7个方法

浅谈TypeScript中值得了解的7个方法

Sep 17, 2021 am 10:53 AM
typescript 泛型

本篇文章给大家分享7个你需要知道的TypeScript中的方法,希望对大家有所帮助!

浅谈TypeScript中值得了解的7个方法

TypeScript 中的类型系统是非常强大的。它为我们提供了类型安全。类型系统虽然受人喜爱,但如果我们不规划和设计类型和接口,它也会让我们的代码变得混乱难读。

泛型

避免代码重复中,创建可重用的类型,是我们编写简洁代码重要的一环。泛型是 TypeScript 的一个功能,它允许我们编写可重用的类型。看下面的例子:

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
}
登录后复制

将正确的类型放入Add的泛型中,它可以被用来描述两个数字的相加或两个字符串的连接。我们不需要为每个函数写一个类型,而只需要用泛型做一次。这不仅节省了我们的精力,而且还使我们的代码更加简洁,更不容易出错。

实用类型

TypeScript 原生提供了几个有用的实用类型来帮助我们进行一些常见的类型转换。这些实用类型是全局可用的,它们都使用了泛型。

下面这7个是我经常用到的。

1. Pick<Type, Keys>

Pick会从 Type 中挑选属性集 Keys 来创建一个新的类型,Keys 可以是一个字符串字面或字符串字面的联合。Keys 的值必须是 Type 的键,否则TypeScript编译器会抱怨。当你想通过从有很多属性的对象中挑选某些属性来创建更轻的对象时,这个实用类型特别有用。

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>

OmitPick相反。 Keys 不是说要保留哪些属性,而是指要省略的属性键集。 当我们只想从对象中删除某些属性并保留其他属性时,这个会更有用。

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 构造了一个类型,其所有的类型属性都设置为可选。当我们在编写一个对象的更新逻辑时,这个可能非常有用。

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>

RequiredPartial相反。它构造了一个类型的所有属性都是必填的类型。它可以被用来确保在一个类型中没有可选属性出现。

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<Type>

Readonly 构建了一个类型,其类型的所有属性被设置为只读。重新分配新的值 TS 就会报错。

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 &#39;name&#39; because it is a read-only property.
登录后复制

6. ReturnType<Type>

ReturnType 从一个函数类型的返回类型构建一个类型。当我们处理来自外部库的函数类型并希望基于它们建立自定义类型时,它是非常有用的。

import axios from &#39;axios&#39;

type Response = ReturnType<typeof axios>

function callAPI(): Response{
  return axios("url")
}
登录后复制

除了上面提到的,还有其他实用类型可以帮助我们编写更干净代码。关于实用工具类型的TypeScript文档链接可以在这里找到。

https://www.typescriptlang.org/docs/handbook/utility-types.html

实用类型是TypeScript提供的非常有用的功能。开发人员应该利用它们来避免硬编码类型。要比同事更秀? 这些就是你需要知道的!

本文转载在:https://segmentfault.com/a/1190000040574488

更多编程相关知识,请访问:编程入门!!

以上是浅谈TypeScript中值得了解的7个方法的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1669
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
泛型函数在Golang中解决可变参数类型的问题吗? 泛型函数在Golang中解决可变参数类型的问题吗? Apr 16, 2024 pm 06:12 PM

Go中的泛型函数解决了可变参数类型的问题:泛型函数允许使用类型参数,在运行时指定。这使得编写可以处理不同类型参数的函数成为可能。例如,Max函数是一个泛型函数,它接受两个可比较参数并返回较大值。通过使用泛型函数,我们可以编写更灵活通用的代码,可处理不同类型的参数。

golang中泛型的具体应用场景 golang中泛型的具体应用场景 May 04, 2024 am 11:45 AM

泛型在Go中的应用场景:集合操作:创建适用于任何类型的集合操作,例如过滤。数据结构:编写通用的数据结构,如队列,栈和映射,可存储和操作各种类型的数据。算法:编写通用的算法,如排序,搜索和归约,可处理不同类型的数据。

Java 函数泛型的上限和下限是什么?如何使用? Java 函数泛型的上限和下限是什么?如何使用? Apr 26, 2024 am 11:45 AM

Java函数泛型允许设置上限和下限。上限(extends)指定函数接受或返回的数据类型必须是指定类型的子类型,例如。下限(super)指定函数接受或返回的数据类型必须是指定类型的超类型,例如。泛型使用可提高代码的可重用性和安全性。

Golang泛型对函数签名和参数的影响是什么? Golang泛型对函数签名和参数的影响是什么? Apr 17, 2024 am 08:39 AM

泛型对Go函数签名和参数的影响包括:类型参数:函数签名可包含类型参数,指定函数可使用的类型。类型约束:类型参数可具有约束,指定其必须满足的条件。参数类型推断:编译器可推断未指定类型参数的类型。指定类型:可显式指定参数类型以调用泛型函数。这提高了代码的可重用性和灵活性,允许编写可与多种类型一起使用的函数和类型。

Java 枚举类型如何与泛型配合使用? Java 枚举类型如何与泛型配合使用? May 04, 2024 am 08:36 AM

Java中枚举类型与泛型的结合:声明带泛型的枚举时需添加尖括号,T为类型参数。创建泛型类时,同样需添加尖括号,T为可存储任何类型的类型参数。此结合提高代码灵活性、类型安全性,并简化代码。

泛型函数在Golang中的限制是什么? 泛型函数在Golang中的限制是什么? Apr 16, 2024 pm 05:12 PM

Go泛型函数的限制:仅支持类型参数,不支持值参数。不支持函数递归。不能显式指定类型参数,由编译器推断。

Java 泛型方法如何进行类型推断? Java 泛型方法如何进行类型推断? May 01, 2024 pm 02:45 PM

Java泛型方法可自动推断类型参数,无需明确声明。规则包括:1.使用明确类型声明;2.推断单个类型;3.推导出通配符类型;4.推断构造函数返回值类型。这简化了代码,使其更易于编写和使用泛型方法。

C++模板和泛型的比较? C++模板和泛型的比较? Jun 04, 2024 pm 04:24 PM

C++中模板和泛型的区别:模板:编译时定义,明确类型化,效率高,代码体积小。泛型:运行时类型化,抽象接口,提供灵活性,效率较低。

See all articles