真实案例说明 TypeScript 类型体操的意义
真實(shí)案例說明 TypeScript 類型體操的意義
TypeScript 類型系統(tǒng)支持類型編程,也就是對類型參數(shù)做一系列運(yùn)算產(chǎn)生新的類型。比如這樣:
type isTwo
這種類型編程邏輯可以寫的很復(fù)雜,所以被戲稱為“類型體操”。
它是 TS 中最強(qiáng)大也是最復(fù)雜的部分了 ,屬于深水區(qū)的內(nèi)容。
很多同學(xué)不知道類型編程學(xué)了有什么用 ,好像做業(yè)務(wù)也用不到這個(gè)。那今天我們就來看一個(gè)具體的例子 ,來感受下類型體操的意義 。
我們想實(shí)現(xiàn)這樣一個(gè) JS 方法 :
function parseQueryString(queryStr) {
if (!queryStr || !queryStr.length) {
return { };
}
const queryObj = { };
const items = queryStr.split('&');
items.forEach(item =>{
const [key, value] = item.split('=');
if (queryObj[key]) {
if(Array.isArray(queryObj[key])) {
queryObj[key].push(value);
} else {
queryObj[key] = [queryObj[key], value]
}
} else {
queryObj[key] = value;
}
});
return queryObj;
}
這段代碼很容易看出來就是做 query string 的 parse 的,會(huì)把 'a=1&b=2&c=3' 的字符串 parse 成 { a: 1, b: 2, c: 3 } 返回。如果有同名的 key 的話,就合并到一個(gè)數(shù)組里 。
JS 的邏輯大家寫的比較多,這部分很容易理解:
圖片
那如果要給這個(gè)函數(shù)加上類型 ,大家會(huì)怎么加呢?
我猜 ,大部分人會(huì)這么加:
圖片
參數(shù)是 string 類型,返回值是 parse 之后的對象類型 object。
這樣是可以的
,而且 object 還可以寫成 Record
圖片
Record 是 TS 內(nèi)置的一個(gè)高級類型,是通過映射類型的語法來生成索引類型的 :
type Record
[P in K]: T;
}
比如傳入 'a' | 'b' 作為 key,1 作為 value ,就可以生成這樣索引類型:
圖片
所以這里的 Record
圖片
但是不管是返回值類型為 object 還是 Record
圖片
對于習(xí)慣了 ts 的提示的同學(xué)來說,沒有提示太不爽了。怎么能讓這個(gè)函數(shù)的返回的類型有提示呢?
這就要用到類型編程了。
我們把函數(shù)的類型定義改成這樣 :
圖片
聲明一個(gè)類型參數(shù) Str,約束為 string 類型,函數(shù)參數(shù)的類型指定是這個(gè) Str