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

TypeScript 中的 Any、Unknown、Never 和Void

開發 前端
今天來學習 TS 中幾個比較特殊的類型:Any、Never、Never、Void。

大家好,我是前端西瓜哥。今天來學習 TS 中幾個比較特殊的類型:any、never、never、void。

any

any 表示 任意類型。

它是任意類型的父類,任意類型的值都可以賦予給 any 類型:

// 編譯不會報錯
let anything: any = '前端西瓜哥';

let flag: boolean = true;
anything = flag;

anything = { num: 2 };

它可以表示任何類型,并使用它們的語法,就像寫沒有類型的原生 JS 一樣。

// 編譯不會報錯
const a: any = 6;

a();
a.key1 = true;

any 相當于拋棄了類型系統,會讓代碼變得不可預測和難以維護,需要程序員小心維護,一有不慎會造成運行時的錯誤,所以盡量少用。

但在引入一些沒有提供類型的第三方純 JS 庫時,還是得將它們標為 any,這個確實沒啥辦法。

除非你自己給第三方庫寫類型聲明,但太不現實,因為你不熟悉第三方庫的 API,且可能有很復雜的類型推導要實現。

any 的存在是為了兼容無類型的 JS。TS 作為 JS 的超集,用 any 開后門是不得不做的事情。

unknown

unknown 可以認為是 類型更安全的 any

和 any 一樣,unknown 也是任何類型的子類型,所有類型都可以傳給 unknown,包括 any。

// 編譯不會報錯
let a: unknown = '前端西瓜哥';

let b: any;
a = b;

a = { num: 2 };

說 unknown 更安全,是因為 unknown 是不能進行任何操作的。如果要使用,需要用 as 來進行顯式的類型斷言。

declare const user: known;

// 報錯,unknown 不能被使用
user.toLowerCase();

// 開發者認為 user 是個字符串
// 使用 as 進行類型推斷才能使用
(user as string).toLowerCase();

或者我們可以用類型收窄(Type Narrowing);

declare const user: unknown;

if (typeof user === 'string') {
user.toLowerCase();
}

對于一些可疑的沒有類型的變量,如果你不希望它被不小心使用,此時就可以用 unknown。

總結就是:unknown 能看不能用,想用先類型斷言。

never

never 表示一個 無法被觀測的類型,被賦予了該類型的變量什么都不能做。

使用 never 的一些場景。

(1)一個無法走到 return 返回值的函數,比如一定會拋出錯誤或死循環:

// 這里的 never 表示無法執行到函數返回它的返回值
function foo(): never {
throw new Error('something wrong!')
}

(2)TS 在判斷條件下會做類型的收窄,當類型收縮到無類型可用,類型就變成了 never:

function getData(id: number | string) {
if (typeof id === 'string') {
// id 類型變成了 string
} else if (typeof id === 'number') {
// id 類型變成了 number
} else {
// id 類型變成了 never
}
}

或者做了一種不可能為 true 的類型收窄:

if (typeof id === 'number' && typeof id === 'string') {
// id 不可能同時是 number 和 string
// 所以會變成 never
}

或無法求出交集的交叉類型:

// ImpossibleType 會得到 never
type ImpossibleType = string & number;

(3)類型編程中,在做模式匹配時,如果匹配失敗,還是要返回一個類型的。為了表示失敗,返回一個 never 表示返回的類型是無法被使用的。

比如 TS 內置的 Parameters 高級類型,會通過模式匹配提取函數的參數數組類型。如果無法匹配到參數,會返回 never:

type Parameters<T extends (...args: any) => any> = T extends (...args: infer P) => any ? P : never

(4)類型編程中,將一些類型丟棄。never 在聯合類型以及重映射的 key 中會被丟棄。

比如 TS 內置的 Exclude 高級類型,會將聯合類型 T 中的不屬于 U 的 key 丟棄掉。

type Exclude<T, U> = T extends U ? never : T

type T = Exclude<"a" | "b" | "c", "a">;
// T 的類型為 "b" | "c"
// 其實應該是 never | "b" | "c",但 never 無意義,被丟掉了

void

void 用于表示一個 函數沒有返回值。

function sayHi(): void {
console.log('Hi!');
}

當然在實際 JS 運行時,還是會返回一個默認的 undefined 的。但 TS 給返回值設置為 void,語義更好些。

總結

any 是任意類型,具有所有類型的行為,可被執行,可訪問屬性,超脫于類型系統之外。

unknown 則是類型更安全的 any,同樣可以將任何類型賦給它,但不能執行任何操作,必須用類型斷言來顯示說明類型才能去執行操作。

never 是無法觀測的類型,比如不會執行完的函數的返回值,合并結果不存在的交叉類型。在類型編程中非?;钴S,常用于丟棄一些子類型。

void 就比較簡單,只是代表函數沒有返回值,沒有其他的場景了。

責任編輯:姜華 來源: 前端西瓜哥
相關推薦

2022-02-25 09:06:02

TypeScripnever工具

2021-10-08 08:11:53

SQLAllSome

2022-04-28 21:53:52

TypeScriptany類型

2020-10-23 09:57:23

TypeScriptany代碼

2021-08-17 11:14:49

VoidJSTS

2021-05-20 09:39:28

SQL Server ALLSOME

2020-09-23 09:08:05

typescript

2010-09-24 18:03:38

SQL中EXISTS

2024-12-24 07:20:00

C++std::anyC++17

2021-08-06 06:51:15

TypeScript Any 類型

2021-12-03 18:29:31

GoAny 泛型

2021-08-04 08:33:59

TypeScriptConst Readonly

2021-07-27 06:06:34

TypeScript語言運算符

2023-12-07 11:47:00

TypeScript特殊值

2022-05-06 09:21:21

TypeScriptinterfacetype

2024-05-11 10:19:31

TypeScript類型接口

2022-04-11 08:42:09

TypeScript子類型定義

2022-08-08 09:00:42

TypeScript映射類型

2022-09-02 09:02:44

TypeInterface

2023-04-14 15:44:20

TypeScrip函數重載
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费人成在线观看网站 | 欧美日韩在线精品 | 91大神xh98xh系列全部 | 91精品国产91久久久 | 日韩中文字幕一区二区 | 欧美精品一区二区三区四区 在线 | 久久久天堂 | 99热在线播放 | 在线欧美一区二区 | 99久久久久久久久 | 激情五月综合 | 中文字幕乱码一区二区三区 | 日韩一区二区三区在线播放 | 亚洲一区在线播放 | 日韩免费av一区二区 | 精品日韩一区 | 91精品国产综合久久久久 | 中文字幕一区二区三区不卡 | 日韩在线看片 | 欧美日韩国产精品一区二区 | 91精品国产综合久久精品图片 | 国产日韩视频 | 精品久久国产 | 91高清视频在线观看 | 亚洲视频中文字幕 | 国产一区二区激情视频 | 九九精品在线 | 亚洲一区二区三区在线播放 | 免费观看黄色片视频 | 户外露出一区二区三区 | 精品久久久久国产 | www.成人免费视频 | 操操日| 日本成人福利 | 欧美一级在线 | 午夜不卡一区二区 | 欧美日韩1区2区3区 欧美久久一区 | 国产日韩欧美一区二区在线播放 | 亚洲国产精品久久 | 欧美一区二区在线播放 | 午夜久久久久 |