新聞中心
如果你剛接觸 TypeScript 不久,在閱讀 TypeScript 內(nèi)置工具類型的用法和內(nèi)部實現(xiàn)的文章時,可能會看到 Pick 工具類型,對于該類型的語法你可能會感到陌生。

創(chuàng)新互聯(lián)建站秉承實現(xiàn)全網(wǎng)價值營銷的理念,以專業(yè)定制企業(yè)官網(wǎng),網(wǎng)站制作、成都網(wǎng)站建設(shè),微信小程序開發(fā),網(wǎng)頁設(shè)計制作,成都手機網(wǎng)站制作,全網(wǎng)營銷推廣幫助傳統(tǒng)企業(yè)實現(xiàn)“互聯(lián)網(wǎng)+”轉(zhuǎn)型升級專業(yè)定制企業(yè)官網(wǎng),公司注重人才、技術(shù)和管理,匯聚了一批優(yōu)秀的互聯(lián)網(wǎng)技術(shù)人才,對客戶都以感恩的心態(tài)奉獻自己的專業(yè)和所長。
type Pick= {
[P in K]: T[P];
};
type User = {
id: number;
name: string;
address: string;
};
type PickedUser = Pick;
其實學(xué)習(xí)新事物一種比較好的方式是使用類比。接下來阿寶哥將借助 JavaScript 中的函數(shù)來幫助你快速理解 Pick 工具類型背后的語法。
function Pick(obj, keys) {
const ret = {};
for (const key of keys) {
ret[key] = obj[key];
}
return ret;
}
const user = {
id: 666,
name: "阿寶哥",
address: "廈門",
};
const PickedUser = MyPick(user, ["id", "name"]);在以上代碼中,function 是關(guān)鍵字用于聲明函數(shù),Pick 是函數(shù)名稱,而小括號內(nèi)的 obj 和 keys 是參數(shù),大括號中定義的是函數(shù)體。
而對于 Pick 工具類型來說,type 關(guān)鍵字用于給類型取個別名,方便重復(fù)使用,Pick 就是類型的名稱。尖括號內(nèi)的 T 和 K 屬于類型參數(shù),與 JavaScript 函數(shù)中參數(shù)的區(qū)別是類型參數(shù)存儲的是類型,而 JavaScript 函數(shù)參數(shù)存儲的是值。
?其中 extends 是泛型約束的語法,用于約束類型的范圍。 大括號中是該工具類型的具體實現(xiàn),它使用了 TypeScript 映射類型的語法。?
其實,你可以把 TypeScript 內(nèi)置的工具類型理解成特殊的函數(shù),它們被用于處理 TypeScript 中存在的類型。調(diào)用工具類型的方式與調(diào)用 JavaScript 函數(shù)的區(qū)別是使用的是尖括號。
最后,為了便于大家理解,阿寶哥以圖片的形式來演示一下 Pick 工具類型的執(zhí)行過程。
如果你想詳細了解映射類型,可以觀看 “??用了 TS 映射類型,同事直呼內(nèi)行!”?? 這篇文章。
網(wǎng)頁題目:秒懂TypeScript泛型工具類型!
鏈接地址:http://fisionsoft.com.cn/article/ccocogd.html


咨詢
建站咨詢
