TS的类型运算符你都知道几个?

什么是类型运算符

TS中,类型系统是其最知名的功能,它让开发者能够在编码过程中更早地发现和修复错误,提高代码的可靠性和可维护性。类型运算符是TS中的一个功能,它们允许开发者对已有的类型进行计算,得到新类型。 这篇文章将会详细的介绍TS中的一些类型运算符。

keyof 运算符

keyof接受一个对象类型作为参数,返回该对象的所有键名组成的联合类型。

TS 复制代码
type MyObj = {
  foo: number,
  bar: string,
};

type Keys = keyof MyObj; // 'foo'|'bar'

keyof 的所有返回类型

由于对象的键名只有三种类型,所以对于任意对象的键名的联合类型就是string|number|symbol

TS 复制代码
// string | number | symbol
    type Keys = keyof any;

对于没有自定义键名的类型使用 keyof 运算符,返回never类型,表示不可能有这样类型的键名。

由于object类型没有自身的属性,也就没有键名,所以keyof object返回never类型。

TS 复制代码
type Keys = keyof object;  // never

如果对象属性名采用索引形式,keyof会返回属性名的索引类型。

TS 复制代码
// 示例一
interface T {
  [prop: number]: number;
}

// number
type KeyT = keyof T;

// 示例二
interface T {
  [prop: string]: number;
}

// string|number
type KeyT = keyof T;

对于联合类型,keyof返回成员共有的键名。

TS 复制代码
type A = { a: string; z: boolean };
type B = { b: string; z: boolean };

// 返回 'z'
type KeyT = keyof (A | B);

对于交叉类型,keyof返回所有键名。

css 复制代码
type A = { a: string; x: boolean };
type B = { b: string; y: number };

// 返回 'a' | 'x' | 'b' | 'y'
type KeyT = keyof (A & B);

// 相当于
keyof (A & B) ≡ keyof A | keyof B

in 运算符

JS中,in运算符用来确定对象是否包含某个属性名。

JS 复制代码
const obj = { a: 123 };

if ('a' in obj) console.log('found a');

TS语言的类型运算中,in运算符有不同的用法,用来遍历联合类型的每一个成员类型。

TS 复制代码
type U = 'a'|'b'|'c';

type Foo = {
  [Prop in U]: number;
};
// 等同于
type Foo = {
  a: number,
  b: number,
  c: number
};

方括号运算符

方括号运算符([])用于取出对象的键值类型,比如T[K]会返回对象T的属性K的类型。

TS 复制代码
type Person = {
  age: number;
  name: string;
  alive: boolean;
};

// Age 的类型是 number
type Age = Person['age'];

方括号的参数如果是联合类型,那么返回的也是联合类型。

TS 复制代码
type Person = {
  age: number;
  name: string;
  alive: boolean;
};

// number|string
type T = Person['age'|'name'];

// number|string|boolean
type A = Person[keyof Person];

访问不存在的属性,则会报错。

TS 复制代码
type T = Person['notExisted']; // 报错

方括号运算符的参数也可以是属性名的索引类型。

TS 复制代码
type Obj = {
  [key:string]: number,
};

// number
type T = Obj[string];

方括号里面不能有值的运算。

TS 复制代码
const key = 'age';
type Age = Person[key]; // 报错
type Age = Person['a' + 'g' + 'e']; // 报错

extends...?: 条件运算符

TS提供类似JS?:运算符这样的三元运算符,但多出了一个extends关键字。条件运算符extends...?:可以根据当前类型是否符合某种条件,返回不同的类型。

TS 复制代码
T extends U ? X : Y

is运算符

函数返回布尔值的时候,可以使用is运算符,限定返回值与参数之间的关系。is运算符用来描述返回值属于true还是false 写法采用parameterName is Type的形式,即左侧为当前函数的参数名,右侧为某一种类型。它返回一个布尔值,表示左侧参数是否属于右侧的类型。

TS 复制代码
type A = { a: string };
type B = { b: string };

function isTypeA(x: A | B): x is A {
    return 'a' in x; 
}
相关推荐
正小安18 分钟前
如何在微信小程序中实现分包加载和预下载
前端·微信小程序·小程序
_.Switch2 小时前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j
一路向前的月光2 小时前
Vue2中的监听和计算属性的区别
前端·javascript·vue.js
长路 ㅤ   2 小时前
vite学习教程06、vite.config.js配置
前端·vite配置·端口设置·本地开发
长路 ㅤ   2 小时前
vue-live2d看板娘集成方案设计使用教程
前端·javascript·vue.js·live2d
Fan_web2 小时前
jQuery——事件委托
开发语言·前端·javascript·css·jquery
安冬的码畜日常2 小时前
【CSS in Depth 2 精译_044】第七章 响应式设计概述
前端·css·css3·html5·响应式设计·响应式
莹雨潇潇3 小时前
Docker 快速入门(Ubuntu版)
java·前端·docker·容器
Jiaberrr3 小时前
Element UI教程:如何将Radio单选框的圆框改为方框
前端·javascript·vue.js·ui·elementui
Tiffany_Ho4 小时前
【TypeScript】知识点梳理(三)
前端·typescript