成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

TS typeof 操作符原來有這五種用途!

開發 前端
本文阿寶哥將介紹 typeof 操作符的幾種常見的應用場景,在以后的項目中,也許你就可以用得上了。

在 JavaScript 中你可以通過 typeof 操作符來獲取變量的類型,那么你知道在 TypeScript 中 typeof 操作符有哪些用途么?

本文阿寶哥將介紹 typeof 操作符的幾種常見的應用場景,在以后的項目中,也許你就可以用得上了。

這是一個普通的 JavaScript 對象,在 TypeScript 中你可以使用 type 或 interface 來定義該對象的類型。有了該對象類型之后,你就可以利用 TypeScript 內置的工具類型,比如 Partial、Required、Pick 或 Readonly 等來處理對象類型,從而滿足不同的業務需求。

const lolo = {
name: "lolo",
age: 7,
address: {
province: "福建",
city: "廈門",
},
};
interface Person {
name: string;
age: number;
address: {
province: string;
city: string;
};
}

對于簡單的對象來說,這也許不算什么。但對于嵌套層級比較深的復雜大對象來說,手動定義其類型會令人腦殼疼。針對這個問題,你可以使用 typeof 操作符:

type Person = typeof lolo;
type Address = typeof lolo["address"];

圖片

相比前面手動定義類型,使用 typeof 操作符之后是不是覺得簡單很多。在 TypeScript 中,枚舉類型是一種特殊的類型,它會被編譯成普通的 JavaScript 對象:

enum HttpMethod {
Get,
Post,
}
"use strict";
var HttpMethod;
(function (HttpMethod) {
HttpMethod[HttpMethod["Get"] = 0] = "Get";
HttpMethod[HttpMethod["Post"] = 1] = "Post";
})(HttpMethod || (HttpMethod = {}));

因此,你也可以對枚舉類型使用 typeof 操作符。但這往往沒有多大的實際用途,處理枚舉類型時,一般還會搭配 keyof 操作符:

const method: typeof HttpMethod = {
Get: 0,
Post: 1,
};
type Method = keyof typeof HttpMethod; // "Get" | "Post"

圖片

由以上結果可知,利用 keyof 和 typeof 操作符,你就可以獲取枚舉類型的所有屬性名。

在日常工作中,typeof 操作符還有另一個比較常見的使用場景。即利用它來獲取函數對象的類型,在獲取對應的函數類型之后,你可以繼續利用 TypeScript 內置的 ReturnType 和 Parameters 工具類型來分別獲取函數的返回值類型和參數類型:

function add(a: number, b: number) {
return a + b;
}
type AddType = typeof add; // (a: number, b: number) => number
type AddReturnType = ReturnType<AddType> // number
type AddParamsType = Parameters<AddType> // [a: number, b: number]

圖片

既然 typeof 操作符可以處理函數對象,那么它可以處理 Class 么?答案是可以的。

class Point {
x: number;
y: number;
constructor(x: number, y: number) {
this.x = x;
this.y = y;
}
}
// new (x: number, y: number) => Point
function createPoint(Constructor: typeof Point, x: number, y: number) {
return new Constructor(x, y);
}

圖片

在以上代碼中,createPoint 是一個工廠函數,用于快速創建 Point 類的實例。通過 typeof 操作符,你就可以獲取 Point 類對應的構造簽名,從而實現相應的類型校驗。在定義 Constructor 參數類型時,如果不使用 typeof 操作符的話,將會出現以下錯誤信息:

function createPoint(Constructor: Point, x: number, y: number) {
return new Constructor(x, y); // Error:類型 "Point" 沒有構造簽名。ts(2351)
}

圖片

此外,在使用 typeof 操作符的過程中,如果你想要獲取更精確的類型,那么你可以結合 TypeScript 3.4 版本中引入的 const 斷言。具體的使用方式如下:

let requestMethod = "Get";
let requestMethod2 = "Get" as const;
type R0 = typeof requestMethod; // string
type R1 = typeof requestMethod2; // "Get"
let user = {
id: 666,
name: "阿寶哥",
};
let user2 = {
id: 666,
name: "阿寶哥",
} as const;
// { id: number; name: string; }
type U0 = typeof user;
// type U1 = { readonly id: 666; readonly name: "阿寶哥"; }
type U1 = typeof user2;

圖片

由以上結果可知,使用 const 斷言之后,再利用 typeof 操作符,我們就可以獲得更精確的類型。

關于 const 斷言相關的知識點,感興趣的話,你可以自行了解一下。而如果你對前面使用過的 keyof 操作符還不了解的話,可以觀看 “??TS 內置工具類型中的 keyof 操作符有啥用???” 這篇文章。 

責任編輯:姜華 來源: 全棧修仙之路
相關推薦

2018-09-29 05:12:54

廣域網網絡連接DDN

2024-05-23 13:54:40

2023-06-27 09:21:33

2025-06-23 00:00:05

2021-10-31 18:59:55

Python操作符用法

2010-07-14 14:55:07

Perl操作符

2009-08-19 17:26:28

C# 操作符

2009-11-17 10:42:58

PHP操作符

2017-07-12 08:20:32

閃存用途企業

2022-04-19 21:05:03

JavaScript內置工具

2024-07-12 11:54:38

2011-04-08 16:26:14

JavaScript

2010-07-14 14:30:31

Perl操作符

2010-07-19 11:00:24

Perl操作符

2009-07-21 09:31:00

Scala操作符

2009-09-15 17:16:58

LINQ查詢操作符

2010-07-14 14:18:51

Perl操作符

2012-02-06 09:13:23

LINQ

2009-09-16 09:09:23

Linq Contai

2025-04-14 08:10:00

負載均衡代碼java
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一级视频在线 | 久久精品小视频 | 中文字幕av亚洲精品一部二部 | 天天操天天玩 | 91国内视频在线 | 欧美一区免费在线观看 | 91精品国产一区二区三区 | 影视先锋av资源噜噜 | 午夜欧美一区二区三区在线播放 | 国产午夜精品视频 | 亚洲一区久久 | 欧美日韩精品一区二区三区蜜桃 | 激情小说综合网 | 亚洲国产精品久久久久秋霞不卡 | 日韩精品久久一区 | 亚洲综合在线视频 | 成人福利网站 | 国产日韩欧美在线一区 | av黄色在线观看 | 日韩欧美一区二区在线播放 | 精品一区二区三区四区五区 | 久久婷婷av | 亚洲狠狠爱 | 亚洲精品久久久久久一区二区 | 亚洲国产69 | www.47久久青青| 国产精品一区视频 | 九九视频网 | 亚洲综合一区二区三区 | 久久久久国产一区二区三区不卡 | 成人久久一区 | 国产精品免费视频一区 | 一级片在线观看 | 91人人爽| 九九久久国产 | 日韩一二区在线观看 | 欧洲精品视频一区 | 日本精品视频在线观看 | 久久久高清 | 日韩精品二区 | 一级黄在线观看 |