精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

TypeScript 中的 Extends 怎么那么優(yōu)秀???

開(kāi)發(fā) 后端
在 JS 核心進(jìn)階中,我們?cè)趯W(xué)習(xí)設(shè)計(jì)模式的時(shí)候,曾經(jīng)提高過(guò)一個(gè)原則:里氏替換原則,該原則針對(duì)的是父類(lèi)與子類(lèi)之間的替換關(guān)系:任何使用父類(lèi)實(shí)例的地方,都能夠使用子類(lèi)實(shí)例完美替換。

在學(xué)習(xí)和使用 ts 的時(shí)候,有一個(gè)語(yǔ)法會(huì)大量的出現(xiàn),他就是 extends。但是這個(gè)語(yǔ)法放到 ts 里,就顯得非常怪異,因?yàn)楹枚鄷r(shí)候跟我們常規(guī)的理解看上去好像不太一樣,不就是一個(gè)繼承嗎,咋到處都在亂用啊?

實(shí)際上,之所以怪,是因?yàn)樵?ts 中,extends 不只是要表達(dá)繼承的意思,他還有一些延展含義。

在 JS 核心進(jìn)階中,我們?cè)趯W(xué)習(xí)設(shè)計(jì)模式的時(shí)候,曾經(jīng)提高過(guò)一個(gè)原則:里氏替換原則,該原則針對(duì)的是父類(lèi)與子類(lèi)之間的替換關(guān)系:任何使用父類(lèi)實(shí)例的地方,都能夠使用子類(lèi)實(shí)例完美替換。

class Person {
  constructor(name) {
    this.name = name
  }
  run(t) {
    console.log(`${this.name} 跑了 ${t} 公里`);
  }
}

class Student extends Person {
  constructor(name, grade) {
    super(name)
    this.grade = grade
  }
}

const p1 = new Person('Tom')
p1.run(20)
const s1 = new Student('Tom')
s1.run(20)

這個(gè)案例中,我們能夠使用 s1 去替換 p1。而不會(huì)出現(xiàn)什么問(wèn)題。

在 ts 的類(lèi)型兼容性里,也符合這個(gè)原則?;谶@個(gè)邏輯,我們就可以把 extends 作為一個(gè)判斷條件,來(lái)驗(yàn)證你是否合理運(yùn)用了里氏替換原則,從而衍生出它新的用法。

一、繼承

繼承的運(yùn)用非常的常規(guī)。在面向?qū)ο蟮倪\(yùn)用中,我們可以繼承一個(gè)父類(lèi)。

class Parent {}
class Children extends Parent {}

我們也可以在 interface 的類(lèi)型聲明中,使用繼承。

interface Animal {
  kind: string
}
interface Dog extends Animal {
  bark(): void
}

它等價(jià)于。

interface Dog {
  kind: string
  bark(): void
}

二、泛型約束

我們先簡(jiǎn)單來(lái)看一下這個(gè)東西是如何在泛型中使用的,然后再來(lái)結(jié)合里氏替換原則來(lái)分析它的邏輯。

interface Dispatch<T extends { type: string }> {
  (action: T): T
}

我們?cè)诙x Dispatch 時(shí)需要傳入一個(gè)泛型,傳入的泛型類(lèi)型必須與 {type: string} 符合里氏替換原則。意思就是說(shuō),要傳入該類(lèi)型的子類(lèi)型。

因此,我們可以傳入。

var action = {
  type: 'get/list',
  playload: 10
}

也可以傳入。

var action = {
  type: 'merge'
}
var action = {
  type: 'add',
  value: { a: 1, b: 2 }
}

從結(jié)論上來(lái)看,父類(lèi)型的約束力度更小,子類(lèi)型的約束力度更大。

三、條件判斷

我們可以可以繼續(xù)衍生,當(dāng)子類(lèi)型與父類(lèi)型符合正常的繼承關(guān)系時(shí),判斷結(jié)果為 true,否則為 false。

這里的繼承關(guān)系,表達(dá)的是一種替換關(guān)系,或者說(shuō)是約束力度的縮小。

type C = A extends B ? string : number

這里表達(dá)的含義是,當(dāng) A 能夠替換 B 時(shí),判斷結(jié)果為 true,否則,判斷結(jié)果為 false。

interface Person {
  name: string
}

interface Yung extends Person {
  gender: string
}

interface Student extends Yung {
  age: string
}

也就是說(shuō),當(dāng) A 作為 B 的子類(lèi)型時(shí),判斷結(jié)果為 true。

// 此時(shí)判斷結(jié)果為true
type C = Yung extends Person ? number : string // number
// 此時(shí)判斷結(jié)果為false
type C = Yung extends Student ? number : string // string

也可以結(jié)合泛型使用。

type P<T> = T extends string ? string : number

type Z = P<string> // string

當(dāng)我們?cè)谑褂梅盒偷臅r(shí)候,會(huì)出現(xiàn)一些問(wèn)題,看一下這個(gè)例子。

type A = number | string extends string ? string : number // number

因?yàn)?string 的約束力度,比 number | string 更大,因此這里的條件判斷為 false,但是當(dāng)我們通過(guò)泛型來(lái)做到同樣的事情時(shí),情況就發(fā)生了變化。

type P<T> = T extends string ? string : number
type A = P<number | string> // string | number

當(dāng)我們用泛型傳遞時(shí)候,跟預(yù)想中的不太一樣,這里會(huì)把泛型傳入的 number 和 string 拆分之后在去運(yùn)行 extends 判斷。因此最后的結(jié)果是 string | number。

聯(lián)合類(lèi)型在泛型中的表現(xiàn)是分配之后再傳入。

在實(shí)踐中一定要警惕這個(gè)小小的差異。我們可以使用如下的方式避免這種先分配再傳入的規(guī)則。

type P<T> = [T] extends [string] ? string : number
type A = P<number | string> // number

never 表示所有類(lèi)型的子類(lèi)型,因此也被看成是一個(gè)聯(lián)合類(lèi)型,當(dāng)我們?cè)诜盒椭袀魅?nbsp;never 時(shí)也會(huì)同理出現(xiàn)同樣的問(wèn)題。

type P<T> = T extends string ? string : number
// 沒(méi)有類(lèi)型可分配,直接返回 never
type A = P<never> // never

注意他們的不同。

type P<T> = [T] extends [string] ? string : number
type A = P<never> // string

四、定義一個(gè) pick

現(xiàn)有一個(gè)對(duì)象 A 有很多個(gè)屬性,我希望重新定義一個(gè)新的對(duì)象 B,該對(duì)象的屬性是從 A 里挑選出來(lái)的,那么 B 的類(lèi)型應(yīng)該怎么定義呢。

interface A {
  name: string;
  age: number;
  gender: number;
  class: string
}

當(dāng)然,我們可以用常規(guī)的方式來(lái)定義,不過(guò)有的時(shí)候這樣會(huì)比較麻煩。

interface B {
  name: string,
  age: number
}

我們也可以利用泛型和 extends,定義一個(gè) Pick 類(lèi)型。

type Pick<T, K extends keyof T> = {
  [P in K]: T[P]
}

type B = Pick<A, 'name' | 'age'>

當(dāng)我們?cè)?Pick 中傳入 A 時(shí), keyof A 的結(jié)果為 name | age | gender | class,因此 'name' | 'age' 是 keyof A 的子類(lèi)型。

此時(shí)的 B 得到與上面寫(xiě)法一樣的結(jié)果。

五、定義一個(gè) Exclude

現(xiàn)在我有一個(gè)聯(lián)合類(lèi)型。

type a = 'name' | 'age' | 'gender' | 'class'

我希望排除其中一個(gè) name,得到一個(gè)新的聯(lián)合類(lèi)型。

type b = 'age' | 'gender' | 'class'

此時(shí)我們可以定一個(gè)排除的泛型類(lèi)型來(lái)做到這個(gè)事情。

type b = Exclude<a, 'name'>

這個(gè) Exclude 是如何實(shí)現(xiàn)的呢?非常的簡(jiǎn)單。

type Exclude<T, U> = T extends U ? never : T
type b = Exclude<a, 'name'>

我們來(lái)分析一下,首先剛才我們已經(jīng)知道,當(dāng)傳入的泛型為聯(lián)合類(lèi)型時(shí),會(huì)先分配再傳入。

因此,此時(shí)傳入的聯(lián)合類(lèi)型 a 會(huì)被拆分傳入。

也就是說(shuō),T exnteds U 的比較會(huì)變成。

// never
'name' extends 'name' ? never : 'name'
// age
'age' extends 'name' ? never : 'age'
// gender
'gender' extends 'name' ? never : 'gender'
// class
'class' extends 'name' ? never : 'class'

所以通過(guò)這種方式,我們可以做到從聯(lián)合類(lèi)型中排除指定的類(lèi)型。

六、定義一個(gè) Omit

Omit 是 Pick 的取反,表示挑選剩余的屬性組成新的對(duì)象。理解了 Pick 和 Exclude,這個(gè)理解起來(lái)非常容易。

type Omit<T, K> = Pick<T, Exclude<keyof T, K>>

使用:

interface A {
  name: string,
  age: number,
  gender: number,
  class: string
}

type B = Omit<A, 'name'>

等價(jià)于:

interface A {
  age: number,
  gender: number,
  class: string
}

大家可以自己分析一下 Omit 的實(shí)現(xiàn)原理,應(yīng)該是沒(méi)有任何難度的。

七、最后

最后來(lái)個(gè)騷的,大家分析一下這玩意兒有什么用

type TypeString<T> =
    T extends string ? "string" :
    T extends number ? "number" :
    T extends boolean ? "boolean" :
    T extends undefined ? "undefined" :
    T extends Function ? "function" :
    "object";
責(zé)任編輯:姜華 來(lái)源: 這波能反殺
相關(guān)推薦

2024-01-24 08:31:13

extends?接口規(guī)范

2022-08-19 12:12:02

TypeScriptInfer 類(lèi)型

2020-06-01 09:40:06

開(kāi)發(fā)ReactTypeScript

2022-08-19 09:01:59

ReactTS類(lèi)型

2010-02-07 13:45:12

Android操作系統(tǒng)

2020-09-13 09:16:17

TypeScriptJavaScript開(kāi)發(fā)

2018-11-08 14:39:50

Excel表結(jié)構(gòu)數(shù)據(jù)

2021-05-08 09:25:52

開(kāi)發(fā)技能代碼

2021-07-27 06:06:34

TypeScript語(yǔ)言運(yùn)算符

2015-11-02 09:36:59

Javasuperextends

2021-08-09 11:16:04

監(jiān)控系統(tǒng)架構(gòu)技術(shù)

2022-08-08 09:00:42

TypeScript映射類(lèi)型

2020-09-23 09:08:05

typescript

2024-05-11 10:19:31

TypeScript類(lèi)型接口

2022-04-11 08:42:09

TypeScript子類(lèi)型定義

2024-11-28 09:43:04

2021-07-01 15:17:14

MYSQL存儲(chǔ)數(shù)據(jù)庫(kù)

2023-12-28 12:07:21

2016-06-08 13:42:08

2020-03-13 14:45:14

Java枚舉代碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

亚洲欧洲精品在线观看| 国产精品成人久久久久| 无码人妻丰满熟妇啪啪网站| 欧产日产国产精品视频| 久久久99精品久久| 国产日韩在线免费| 国产一二三四在线| 奇米狠狠一区二区三区| 日韩视频免费观看高清在线视频| 777久久久精品一区二区三区| 91吃瓜网在线观看| 成人一道本在线| 国产精品亚洲网站| 日本少妇bbwbbw精品| 久久亚洲影视| 亚洲人成网站在线播| 熟妇女人妻丰满少妇中文字幕| 日韩欧美另类一区二区| 亚洲一区二区三区在线看| 日韩一本精品| 偷拍自拍在线| 成人综合婷婷国产精品久久蜜臀| 国产精品小说在线| 丁香社区五月天| 一区在线免费| 久久国产精品偷| 9.1片黄在线观看| 婷婷精品在线| 欧美精品一区二区蜜臀亚洲| 小早川怜子一区二区三区| 四虎4545www国产精品| 午夜精品久久久久久久 | 国产黄色免费大片| 免费视频一区二区| 日韩暖暖在线视频| 日韩成人在线免费视频| 国产精品红桃| 欧美精品在线第一页| 亚洲a∨无码无在线观看| 国产亚洲一卡2卡3卡4卡新区 | 99热免费精品| 欧美激情性做爰免费视频| 国模视频一区二区| 日本三级中国三级99人妇网站| 亚洲av无码乱码在线观看性色| 久久99精品国产麻豆不卡| 国产精品激情av电影在线观看| 日韩人妻精品中文字幕| 国产精品亚洲欧美| 欧美一区二区三区……| 国产精品午夜影院| 模特精品在线| 国产不卡视频在线| wwwwww在线观看| 免费成人美女在线观看.| 国产精品免费一区豆花| 中文字幕在线观看1| 日韩成人精品在线| 国产欧美精品xxxx另类| 中文字幕亚洲乱码熟女1区2区| 每日更新成人在线视频| 国产成人精品av| 销魂美女一区二区| 美女脱光内衣内裤视频久久网站 | 久久99国产精品自在自在app| 欧美日韩午夜视频| 欧美日韩亚洲国产精品| 欧美第一黄网免费网站| 国产午夜免费视频| 免费一级欧美片在线播放| 国产精品99蜜臀久久不卡二区 | 日韩1区2区日韩1区2区| 国产乱人伦真实精品视频| 国产精品一级视频| 粉嫩蜜臀av国产精品网站| 国产日韩亚洲精品| 久草视频视频在线播放| 国产精品久久久久久久久免费丝袜 | 国产成人久久婷婷精品流白浆| 秋霞国产精品| 日韩欧美亚洲一区二区| 亚洲精品乱码久久久久久久| 激情综合网站| 欧美大片网站在线观看| 国产午夜免费福利| 久久精品久久综合| 国产麻豆一区二区三区在线观看| 久青草国产在线| 亚洲日本欧美天堂| 国产中文字幕免费观看| va天堂va亚洲va影视| 亚洲第一免费播放区| 国产黄片一区二区三区| 一区二区三区四区电影| 91国自产精品中文字幕亚洲| ,一级淫片a看免费| 不卡的av网站| 中文精品视频一区二区在线观看| 91jq激情在线观看| 欧美视频一区二| 中文字幕免费高清视频| 五月开心六月丁香综合色啪| 51久久精品夜色国产麻豆| 国产尤物视频在线观看| 久久人人97超碰com| 日韩不卡一二区| 日韩欧美一区二区三区免费观看| 日韩三级在线免费观看| 国产三级短视频| 日韩一级欧洲| 亚洲一区二区三区四区在线播放| 免费在线一级视频| 一区二区三区欧美在线观看| 欧美黄色性生活| 欧美日韩精品一区二区三区在线观看| 久久精品中文字幕电影| 亚洲成人第一网站| 成人国产亚洲欧美成人综合网| 亚洲欧美精品在线观看| 日韩电影免费观| 亚洲精品第一页| 久久久精品一区二区涩爱| 久久精品国产精品青草| 日韩亚洲不卡在线| 精品国产第一福利网站| 亚洲成人久久一区| 青青草手机在线观看| 九九精品视频在线看| 欧美另类高清视频在线| 色资源二区在线视频| 欧美va天堂va视频va在线| 日本中文在线视频| 久久99久久99| 亚洲黄色一区二区三区| 日韩高清成人| 亚洲一区二区久久久| 中文在线第一页| 久久尤物电影视频在线观看| 男人操女人逼免费视频| 国产精品色在线网站| 色综合五月天导航| 日本wwwxxxx| 亚洲不卡在线观看| 97精品人妻一区二区三区蜜桃| 欧美视频网站| 国产乱码精品一区二区三区中文| 色图在线观看| 亚洲аv电影天堂网| 亚洲精品在线观看av| 成人av在线看| 亚洲国产精品久久久久婷蜜芽| 欧美激情极品| 欧美在线视频网站| 黄色网址在线播放| 欧美日韩精品一区二区| 最新日韩免费视频| 狠狠色丁香久久婷婷综| 日本一区二区三区四区五区六区| 高清一区二区| 欧美激情图片区| 日中文字幕在线| 91福利精品视频| 影音先锋男人看片资源| 国内精品在线播放| 日韩精品一区二区在线视频 | 精品无码人妻一区二区三区| 成人深夜视频在线观看| 久久无码高潮喷水| 成人3d精品动漫精品一二三| 成人精品一区二区三区| 女同视频在线观看| 日韩av在线网址| 久草热在线观看| 亚洲乱码国产乱码精品精98午夜 | 黄色一级大片在线免费看国产| 精品高清美女精品国产区| 国产一区二区三区四区五区六区| 麻豆精品国产传媒mv男同| 青草网在线观看| 久久99国产精品视频| 成人妇女淫片aaaa视频| 激情网站在线| 亚洲天堂久久av| 国内老熟妇对白hdxxxx| 欧美日韩亚洲91| 天堂网中文在线观看| 成人av免费在线| 少妇激情一区二区三区| 欧美人成网站| 日韩欧美在线电影| 91成人在线精品视频| 国产精品6699| 多野结衣av一区| 中文字幕视频一区二区在线有码| 黄色aaa大片| 欧美日韩国产免费一区二区| 成年人免费看毛片| 中文字幕视频一区| 成人无码www在线看免费| 加勒比av一区二区| 日日摸天天爽天天爽视频| 欧美精品97| 亚洲国产高清国产精品| 老司机在线精品视频| 成人黄色网免费| 成人美女黄网站| 欧美精品aaa| 69av亚洲| 亚洲欧洲黄色网| 色婷婷av一区二区三| 欧美乱妇15p| 无码日韩精品一区二区| 亚洲高清在线视频| 午夜国产福利一区二区| 中文字幕乱码一区二区免费| 国产精品无码电影| 成人在线综合网| 韩国一区二区在线播放| 日本视频中文字幕一区二区三区| 精品久久一二三| 亚洲视频中文| 欧美精品一区二区性色a+v| 日韩电影一区| 欧美三级网色| 伊人久久大香线蕉| 好看的日韩精品| 澳门成人av| 超碰97人人人人人蜜桃| 精品人妻午夜一区二区三区四区| 中文字幕一区二区三区久久网站| 日韩精品在在线一区二区中文| 国产欧美三级电影| 国产99在线播放| 一区二区三区自拍视频| 2022国产精品| 日韩精品一区二区三区中文| 成人精品一区二区三区电影黑人| 三级成人在线| 国产成人在线一区| 欧美日韩国产v| 国产成人福利视频| 综合日韩av| 日本一欧美一欧美一亚洲视频 | 日本韩国在线不卡| 天堂√8在线中文| 2019精品视频| 蜜桃麻豆av在线| 538国产精品一区二区免费视频 | 亚洲高清影视| 香蕉视频免费版| 综合天堂av久久久久久久| 亚洲精品白虎| 欧美激情国产在线| 懂色av粉嫩av蜜臀av| 精品国产精品久久一区免费式| 免费不卡亚洲欧美| 国内精品伊人久久久| 亚洲精品不卡| 欧美日韩一区自拍| eeuss中文| 欧美在线视屏| 青青草精品视频在线| 国产欧美综合一区二区三区| 国产精品12345| 久久久久久久高潮| 手机版av在线| 丰满亚洲少妇av| 中文字幕av观看| 亚洲国产精品av| 免费看一级大片| 亚洲成人在线免费| 日韩综合在线观看| 7777精品伊人久久久大香线蕉| www.久久综合| 亚洲片av在线| 国产欧美黑人| 91国产精品视频在线| abab456成人免费网址| 91牛牛免费视频| 美女一区2区| 亚洲欧洲日本国产| 韩国自拍一区| 日本成人黄色网| 国产成人精品影视| 一区二区三区四区免费| 亚洲色图在线视频| 久久久国产精品成人免费| 欧美性大战久久久久久久| 亚洲AV午夜精品| 亚洲一级一级97网| 狂野欧美性猛交xxxxx视频| 国产成人精品视频| 亚洲欧洲国产精品一区| 日韩av一区二区三区在线观看| 欧美一区国产在线| 成人精品视频一区二区| 国产成人自拍网| x88av在线| 亚洲va在线va天堂| 国产精品久久久久久免费播放| 精品国产免费一区二区三区四区| 国产尤物视频在线| 国内精品久久影院| **精品中文字幕一区二区三区| 精品国产一区二区三区麻豆小说 | 国产精品videosex极品| 超碰av在线免费观看| 成人精品鲁一区一区二区| 国产黄色片在线| 精品久久久久久久中文字幕| av小说天堂网| 自拍偷拍亚洲在线| 午夜激情在线播放| 成人综合电影| 91精品国产调教在线观看| 成人在线观看a| 99久久精品国产一区二区三区| 三级av在线免费观看| 在线视频欧美区| 人成免费电影一二三区在线观看| 欧美大秀在线观看| 美国十次综合久久| 伊人久久婷婷色综合98网| 日日摸夜夜添夜夜添精品视频| 2一3sex性hd| 亚洲国产中文字幕| www.麻豆av| 欧美成人性生活| www一区二区三区| 亚洲精品久久久久久一区二区| 免费视频一区二区三区在线观看| 中文字幕影片免费在线观看| 亚洲一区二区高清| 亚洲精品成人电影| 欧美高清视频免费观看| 久久9999免费视频| 欧美一级黄色录像片| 精品亚洲国产成人av制服丝袜 | 国产在线视频不卡| 日产午夜精品一线二线三线| 日韩精品免费播放| 国产婷婷一区二区| 国产成人a v| 中文字幕最新精品| 国产精品久久乐| 一区一区视频| 国产一区二区不卡| 国产少妇在线观看| 日韩亚洲欧美高清| 性欧美高清come| 国产精品一区二区在线观看| 影音先锋中文字幕一区二区| 成人性生活免费看| 欧美日韩免费看| 国产亚洲依依| 国产美女扒开尿口久久久| 97视频精品| 九九九久久久久久久| 亚洲综合无码一区二区| 免费观看的毛片| 国产成人精品最新| 日韩情爱电影在线观看| www.久久久久久久久久久| 亚洲品质自拍视频| 日本高清视频免费观看| 清纯唯美日韩制服另类| 第一会所亚洲原创| 亚洲色图欧美自拍| 婷婷综合久久一区二区三区| 黄色在线视频观看网站| 91色视频在线导航| 极品尤物久久久av免费看| 国产男女猛烈无遮挡a片漫画 | 日本黄色福利视频| 一区二区三区在线视频观看58| 天天操天天干天天舔| 国产大片精品免费永久看nba| 99久久久久| 成人性生活免费看| 欧美色偷偷大香| 免费毛片在线看片免费丝瓜视频 | 日本丶国产丶欧美色综合| 久热国产在线| 黑人巨大精品欧美一区二区小视频| 久久久久国产精品午夜一区| 日本少妇aaa| 亚洲激情免费观看| 亚洲精品66| a级黄色一级片| 综合久久久久久久| 亚洲欧美色视频| 91夜夜揉人人捏人人添红杏| av成人黄色| 欧美精品久久久久久久久46p| 精品视频久久久久久久| 国产日韩一区二区三免费高清| 激情五月开心婷婷| 夜夜精品视频一区二区| 99re在线视频| 欧美不卡在线一区二区三区|