




下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第TypeScript泛型約束條件示例詳解目錄什么是泛型泛型的應用場景泛型約束(限制條件)泛型函數調用指定類型總結
什么是泛型
兩個值之間存在的對應關系,就可以用泛型來解決
泛型的應用場景
當一個函數的返回值的類型需要與此函數的參數類型想關聯(lián)的時候,就需要使用泛型
例如
//約定此函數調用時必須傳入一個數組,并返回數組第一項
functionarrFnT(arr:T[]):T|undefined{
returnarr[0]
constn=arrFn([1,2])//number類型
consts=arrFn(['a','b'])//string類型
constu=arrFn([])//undefined類型
//也可以進行指定類型
arrFnnumber([1,2])//此時數組中元素就必須是number類型
再例如,我們將數組的map方法進行加工
//定義一個map函數
//第一個參數約定傳入一個數組
//第二個參數約定傳入一個函數
//此函數的返回值就是操作之后的數組
functionmapIn,Out(arr:In[],fun:(val:In)=Out):Out[]{
returnarr.map(fun)
constres=map([1,2,3,4,5],(i)=i+1)
console.log(res)///[2,3,4,5,6]
泛型約束(限制條件)
默認情況下,泛型函數的類型變量T可以代表多個類型,這導致在泛型函數內部無法訪問任何屬性
當我們需要用到一些屬性的時候,就無法使用,會報錯,比如字符串、數組的長度
接下來我們看個例子
//定義一個函數,傳入兩個值,來比較哪個更長,相等就返回0
functioncompareTextends{length:number}(a:T,b:T){
if(a.lengthb.length){
returnb
}elseif(a.length===b.length){
return(a.length-b.length)
}else{
returna
constres1=compare('哈哈哈','哈哈哈')
console.log(res1)//0
constres2=compare('我真酷','你酷')
console.log(res2)//'我真酷'
constres3=compare('我酷','你真酷')
console.log(res1)//'你真酷'
當然,當我們在使用泛型約束的時候,也會出現(xiàn)常見的錯誤
//我們定義一個泛型T,并讓其繼承一個有l(wèi)ength屬性的對象
//給參數指定類型,第一個參數為T類型,第二參數為number類型
//返回值也為T類型
constmyTs=Textends{length:number}(obj:T,num:number):T={
if(obj.length=num){
returnobj
}else{
return{length:num}//此處會報錯
}
這個函數的返回值看似沒問題,其實會報錯
我們把這個代碼稍微改造一下,就容易理解了
constmyTs=Textends{length:number}(obj:T,num:number):T={
if(obj.length=num){
returnobj
}else{
constres={length:num}//把鼠標放上res,可以看到res的類型是{length:number}
returnres//但是我們約定的返回值是T類型,
//這里會報錯不能將類型“{length:number;}”分配給類型“T”
}
我們將代碼改造成這樣就是正確的
constmyTs=Textends{length:number}(obj:T,num:number):T={
if(obj.length=num){
returnobj
}else{
obj.length=num
returnobj
constres=myTs({length:3},6)
console.log(res)//{length:6}
泛型函數調用指定類型
在定義完成泛型函數之后,我們去調用函數并傳參的時候,并沒有去指定參數類型,當多個參數類型不同的時候,TS就會報錯,接下來請看一個例子:
定義一個泛型函數,用來連接數組,約定參數必須為數組
//定義一個連接兩個數組的函數
//并約定兩個參數的類型都為泛型數組
//且返回值也為一個泛型數組
constmergeArray=T(arr1:T[],arr2:T[]):T[]={
//concat為數組連接,不會改變原數組,需要使用值接收
returnarr1.concat(arr2)
//但是當我們在使用這個函數的時候就會發(fā)現(xiàn)
//如果第一個參數數組中的元素都為number類型
//而第二個參數數組的類型與第一個不一致時
//TS就會報錯,這樣使用就只能傳入兩個一樣類型的數組參數
mergeArray([1,2,3],['a','b'])//報錯,不能將類型“string”分配給類型“number”
所以當我們調用函數的時候就可以指定參數類型
這樣參數就是我們
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 語音識別試題及答案
- 阿里定級面試題及答案
- 房地產銷售策略與實戰(zhàn)
- 2025年 道真自治縣“特崗計劃”教師招聘考試筆試試卷附答案
- 員工安全培訓手冊
- 2025年中國噴氣背包行業(yè)市場全景分析及前景機遇研判報告
- 2025年中國內衣褲洗衣機行業(yè)市場全景分析及前景機遇研判報告
- 急救培訓圓滿畢業(yè)
- 住院患者護理風險評估制度
- 腫瘤晚期患者教育
- 高壓環(huán)網柜施工方案
- 報銷醫(yī)保委托書
- 2025年內蒙古錫林郭勒盟事業(yè)單位人才引進歷年高頻重點提升(共500題)附帶答案詳解
- 輻射防護復習題及答案
- 各種惡劣天氣行車安全培訓
- 化工裝置報廢拆除施工方案
- 華東理工大學《生物信息學》2021-2022學年第一學期期末試卷
- 《秦腔》課件統(tǒng)編版高中語文選擇性必修下冊
- DB51-T 2975-2022 氣凝膠復合保溫隔熱材料及系統(tǒng)通.用技術條件
- 第三講加快發(fā)展新質生產力-2024年形勢與政策
- 腦出血疑難病例討論護理
評論
0/150
提交評論