




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第TypeScript泛型約束條件示例詳解目錄什么是泛型泛型的應(yīng)用場(chǎng)景泛型約束(限制條件)泛型函數(shù)調(diào)用指定類型總結(jié)
什么是泛型
兩個(gè)值之間存在的對(duì)應(yīng)關(guān)系,就可以用泛型來解決
泛型的應(yīng)用場(chǎng)景
當(dāng)一個(gè)函數(shù)的返回值的類型需要與此函數(shù)的參數(shù)類型想關(guān)聯(lián)的時(shí)候,就需要使用泛型
例如
//約定此函數(shù)調(diào)用時(shí)必須傳入一個(gè)數(shù)組,并返回?cái)?shù)組第一項(xiàng)
functionarrFnT(arr:T[]):T|undefined{
returnarr[0]
constn=arrFn([1,2])//number類型
consts=arrFn(['a','b'])//string類型
constu=arrFn([])//undefined類型
//也可以進(jìn)行指定類型
arrFnnumber([1,2])//此時(shí)數(shù)組中元素就必須是number類型
再例如,我們將數(shù)組的map方法進(jìn)行加工
//定義一個(gè)map函數(shù)
//第一個(gè)參數(shù)約定傳入一個(gè)數(shù)組
//第二個(gè)參數(shù)約定傳入一個(gè)函數(shù)
//此函數(shù)的返回值就是操作之后的數(shù)組
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]
泛型約束(限制條件)
默認(rèn)情況下,泛型函數(shù)的類型變量T可以代表多個(gè)類型,這導(dǎo)致在泛型函數(shù)內(nèi)部無法訪問任何屬性
當(dāng)我們需要用到一些屬性的時(shí)候,就無法使用,會(huì)報(bào)錯(cuò),比如字符串、數(shù)組的長(zhǎng)度
接下來我們看個(gè)例子
//定義一個(gè)函數(shù),傳入兩個(gè)值,來比較哪個(gè)更長(zhǎng),相等就返回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)//'你真酷'
當(dāng)然,當(dāng)我們?cè)谑褂梅盒图s束的時(shí)候,也會(huì)出現(xiàn)常見的錯(cuò)誤
//我們定義一個(gè)泛型T,并讓其繼承一個(gè)有l(wèi)ength屬性的對(duì)象
//給參數(shù)指定類型,第一個(gè)參數(shù)為T類型,第二參數(shù)為number類型
//返回值也為T類型
constmyTs=Textends{length:number}(obj:T,num:number):T={
if(obj.length=num){
returnobj
}else{
return{length:num}//此處會(huì)報(bào)錯(cuò)
}
這個(gè)函數(shù)的返回值看似沒問題,其實(shí)會(huì)報(bào)錯(cuò)
我們把這個(gè)代碼稍微改造一下,就容易理解了
constmyTs=Textends{length:number}(obj:T,num:number):T={
if(obj.length=num){
returnobj
}else{
constres={length:num}//把鼠標(biāo)放上res,可以看到res的類型是{length:number}
returnres//但是我們約定的返回值是T類型,
//這里會(huì)報(bào)錯(cuò)不能將類型“{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}
泛型函數(shù)調(diào)用指定類型
在定義完成泛型函數(shù)之后,我們?nèi)フ{(diào)用函數(shù)并傳參的時(shí)候,并沒有去指定參數(shù)類型,當(dāng)多個(gè)參數(shù)類型不同的時(shí)候,TS就會(huì)報(bào)錯(cuò),接下來請(qǐng)看一個(gè)例子:
定義一個(gè)泛型函數(shù),用來連接數(shù)組,約定參數(shù)必須為數(shù)組
//定義一個(gè)連接兩個(gè)數(shù)組的函數(shù)
//并約定兩個(gè)參數(shù)的類型都為泛型數(shù)組
//且返回值也為一個(gè)泛型數(shù)組
constmergeArray=T(arr1:T[],arr2:T[]):T[]={
//concat為數(shù)組連接,不會(huì)改變?cè)瓟?shù)組,需要使用值接收
returnarr1.concat(arr2)
//但是當(dāng)我們?cè)谑褂眠@個(gè)函數(shù)的時(shí)候就會(huì)發(fā)現(xiàn)
//如果第一個(gè)參數(shù)數(shù)組中的元素都為number類型
//而第二個(gè)參數(shù)數(shù)組的類型與第一個(gè)不一致時(shí)
//TS就會(huì)報(bào)錯(cuò),這樣使用就只能傳入兩個(gè)一樣類型的數(shù)組參數(shù)
mergeArray([1,2,3],['a','b'])//報(bào)錯(cuò),不能將類型“string”分配給類型“number”
所以當(dāng)我們調(diào)用函數(shù)的時(shí)候就可以指定參數(shù)類型
這樣參數(shù)就是我們
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 物流中心造價(jià)控制措施
- 體育設(shè)施EPC采購(gòu)管理計(jì)劃
- 護(hù)士在名師講座中的學(xué)習(xí)心得體會(huì)
- 中國(guó)市場(chǎng)營(yíng)銷部工作總結(jié)和計(jì)劃
- 部編版三年級(jí)語文上自主檢測(cè)評(píng)估計(jì)劃
- 教師師德師風(fēng)與教學(xué)改革心得體會(huì)
- 新部編版一年級(jí)語文上冊(cè)教學(xué)進(jìn)度計(jì)劃
- 電商培訓(xùn)課程教學(xué)質(zhì)量的心得體會(huì)
- 應(yīng)用型本科高校學(xué)生返校心理疏導(dǎo)計(jì)劃
- 部編六年級(jí)語文下冊(cè)第一單元教學(xué)計(jì)劃
- 2024年生活方式酒店研究報(bào)告
- 電影院放映設(shè)備安全操作與維護(hù)
- (高清版)DB11∕T2274-2024水務(wù)工程施工現(xiàn)場(chǎng)安全生產(chǎn)管理導(dǎo)則
- 2024年貴州省普通高中學(xué)業(yè)水平選擇性考試地理試題(原卷版+解析版)
- 中學(xué)高中部教學(xué)樓及食堂建設(shè)項(xiàng)目初步設(shè)計(jì)說明書
- 2022肝癌晚期病人肺栓塞護(hù)理學(xué)習(xí)學(xué)習(xí)
- 2025年1月國(guó)家開放大學(xué)行管專科《行政組織學(xué)》期末紙質(zhì)考試試題及答案
- 《種衣劑知識(shí)培訓(xùn)》課件
- 特種設(shè)備安全管理的應(yīng)急預(yù)案編制
- 2024年重大事故隱患判定標(biāo)準(zhǔn)考核試題
- 人教版八年級(jí)英語上冊(cè) Unit 2 Section A 教案(同步教學(xué)設(shè)計(jì))
評(píng)論
0/150
提交評(píng)論