真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

TypeScript工具類(lèi) Partial 和 Required 的詳細(xì)講解

場(chǎng)景描述:

場(chǎng)景描述:一個(gè)接口(IPerson)有很多個(gè)的字段,可能有幾百。而且這些字段都是必須的。
我們需要使用這個(gè)接口,但是我又不可能使用它的全部。可能只會(huì)使用幾個(gè)。
我還必須要使用這接口。這個(gè)時(shí)候,我們?cè)趺唇鉀Q這個(gè)問(wèn)題呢?
TS給了我們一個(gè)工具類(lèi)Partial,可以解決這隔辦法
Partial  [ pɑ r?l ] [部分的]
使用的方式就是 let obj:Partial<接口名>={  }

工具類(lèi)的使用 Partial

// 這個(gè)接口有這些的字段
interface IPerson {
    name: string;
    age: number;
    sex: "男" | "女"; //只能夠是男或者女,
    address: string,
    xueli: string,
    like: string[],
    height: string,
    weight:number,
    // 可能這個(gè)接口還有很多字段
 }

// 現(xiàn)在我要使用IPerson這個(gè)接口去聲明name, age, sex。
// 我們就可以使用工具類(lèi) Partial。Partial表示我只使用接口中的部分聲明
let zhang: Partial = {
    name: '張三',
    age: 10,
    sex: '女'
}

Partial 是怎么做的

我們將光標(biāo)放在 Partial 上可以看見(jiàn)這樣的描述
type Partial = { [P in keyof T]?: T[P] | undefined; }
什么意思呢? 我們知道是一個(gè)接口。 
[P in keyof T] 中的T其實(shí)就是 IPerson 這個(gè)接口
簡(jiǎn)單點(diǎn)就是翻譯成了下面這樣的樣子
{
    name ?: string | undefined,
    age ?: number | undefined
    sex ?:  "男" | "女" | undefined
   這樣的形式下去
}
通過(guò) Partial 【怕 show兒】聲明后就不會(huì)報(bào)錯(cuò)。達(dá)到使用接口的部分聲明

場(chǎng)景描述

interface IInfoPerson {
    name: string;
    age: number;
    address?: string,
    like?: string[],
}
我們之前聲明了一個(gè)接口。其中有幾個(gè)字段是可選的(address,like )。
現(xiàn)在我們恰好需要使用這個(gè)接口,不過(guò)有幾個(gè)的可選字段要變?yōu)楸仨氉侄巍?我們?cè)趺唇鉀Q這個(gè)問(wèn)題呢?
1.重新聲明一個(gè)接口??梢越鉀Q,但是這樣不好。
2.不用管它。我們心里在使用的時(shí)候知道這幾個(gè)可選的字段是必須字段
3.使用 Required 讀音[r? ?kwa? ? d ] 

工具類(lèi) Required的簡(jiǎn)單使用

// 有兩個(gè)可選字段
interface IInfoPerson {
    name: string;
    age: number;
    address?: string,
    like?: string[],
}

// 通過(guò) Required 將可選字段變?yōu)楸仨氉侄?let lisi: Required = {
    name: '李四',
    age: 10,
    address: '在羅翔老師的視頻中',
    like:['吃飯','睡覺(jué)']
}

// 通過(guò) Required 將可選字段變?yōu)楸仨氉侄?【這個(gè)會(huì)報(bào)錯(cuò)】
let zhang: Required = {
    name: '張三',
    age: 10,
}

Required是怎么做的?

光標(biāo)放在 Required 上會(huì)出現(xiàn)下面的提示內(nèi)容
type Required = { [P in keyof T]-?: T[P]; }
這里的 -? 就是抵消掉問(wèn)號(hào) ?
這就變成了 
{
    name: string;
    age: number;
    address: string,
    like: string[],
}
這樣就不可以缺省了

本文標(biāo)題:TypeScript工具類(lèi) Partial 和 Required 的詳細(xì)講解
分享路徑:http://weahome.cn/article/dsojgdo.html

其他資訊

在線(xiàn)咨詢(xún)

微信咨詢(xún)

電話(huà)咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部