




下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
第那些項目中常見的TypeScript錯誤總結目錄引言1.TS24562.TS25543.TS11694.TS23455.TS25896.TS2322總結
引言
TypeScript錯誤信息由錯誤碼和詳細信息組成。例如:TS2456,其中錯誤碼是以TS開頭+數字(一般是4位數字)結尾這樣的格式組成的字符串,用來作為特定類型錯誤的專屬代號。下面我們看一下那些常?,但在官方文檔甚少提及的類型錯誤:
1.TS2456
首先是由于類型別名循環引用了自身造成的TS2456類型錯誤,如下示例:
typeT=ReadonlyT
//TS2456:Typealias'T'circularlyreferencesitself.
在上面這個例子中,對于T這個類型別名,如果TypeScript編譯器想知道T類型是什么,就需要展開類型別名賦值的Readonly。而為了確定Readonly的類型,TypeScript編譯器需要繼續判斷入參T的類型,這就形成了一個循環引用,類似函數循環調用自己,如果沒有正確的終止條件,就會一直處于無限循環的狀態,所以就會報錯。
2.TS2554
另一個常?的錯誤就是TS2554,它是由于形參和實參個數不匹配造成的,如下:
functiontest(a:number|undefined):string{
if(a===undefined){
return'';
returna.toString();
test();//TS2554:Expected1arguments,butgot0.
test(undefined);
之所以會報錯是因為在ts中,undefined是一個特殊的類型,由于類型為undefined,并不代表可缺省,因此示例中的第8行提示了TS2554錯誤。
3.TS1169
TS1169類型錯誤是在接口類型定義中由于使用了非字面量或者非唯一symbol類型作為屬性名造成的,如下:
interfaceObj{
[keyin'id'|'name']:any;//TS1169:Acomputedpropertynameinaninterfacemustrefertoanexpressionwhosetypeisaliteraltypeora'uniquesymbol'type.
因為interface類型的屬性必須是字面量類型(string、number)或者是uniquesymbol類型,所以在第2行提示了TS1169錯誤。
4.TS2345
TS2345類型錯誤的原因在于傳參時由于類型不兼容造成的,如下:
enumA{
x='x',
y='y',
z='z',
enumB{
x='x',
y='y',
z='z',
functionfn(val:A){}
fn(B.x);//TS2345:Argumentoftype'B.x'isnotassignabletoparameteroftype'A'.;
如上所示,函數fn參數的val類型是枚舉A,在12行我們傳入了與枚舉A類似的枚舉B的值,此時ts提示了類型不匹配的錯誤。這是因為枚舉是在運行時真正存在的對象,因此ts并不會判斷兩個枚舉是否可以互相兼容,所以報錯。解決這個錯誤的方式也很簡單,我們只需要讓這兩個枚舉類型互相兼容就行,比如使用類型斷言繞過ts的類型檢查(fn((B.xasunknown)asA);)即可。
5.TS2589
TS2589類型錯誤是由泛型實例化遞歸嵌套過深造成的,如下:
typeRepeatXNextendsnumber,Textendsany[]=[]=T['length']extendsNT:RepeatXN,[...T,'X']
typeT1=RepeatX5//=["X","X","X","X","X"]
//TS2589:Typeinstantiationisexcessivelydeepandpossiblyinfinite.
因為第1行的泛型RepeatX接收了一個數字類型入參N,并返回了一個?度為N、元素都是X的數組類型,所以第4行的類型T1包含了5個X的數組類型;但是第6行的類型T2的類型卻是any,并且提示了TS2589類型錯誤。這是因為ts在處理遞歸類型的時候,最多實例化50層,如果超出了遞歸層數的限制,ts便不會繼續實例化,并且類型會變為top類型any。對于上面的錯誤,我們使用@ts-ignore注釋忽略即可。
6.TS2322
TS2322錯誤是由于字符串字面量類型定義時導致的錯誤,如下:
interfaceCSSProperties{
display:'block'|'flex'|'grid';
conststyle={
display:'flex',
//TS2322:Type'{display:string;}'isnotassignabletotype'CSSProperties'.
//Typesofproperty'display'areincompatible.
//Type'string'isnotassignabletotype'"block"|"flex"|"grid"'.
constcssStyle:CSSProperties=style;
在上面的例子中,CSSProperties的display屬性的類型是字符串字面量類型block|flex|grid,雖然變量style的display屬性看起來與CSSProperties類型完全兼容,但是TypeScript提示了TS2322類型不兼容的錯誤。這是因為變量style的類型被自動推斷成了{display:string},string類型自然無法兼容字符串字面量類型block|
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 煤礦年度安全活動方案
- 班級中秋活動親子活動方案
- 現代倉庫活動方案
- 王老吉校園活動方案
- 物業年禮專場活動方案
- 愛心進鄉村活動方案
- 燒鴨開店活動方案
- 特步公司營銷策劃方案
- 生活照片征集活動方案
- 煙臺漢服投票活動方案
- 2025至2030中國港口航道工程行業深度研究及發展前景投資評估分析
- 單元復習AB卷:第二十八章 圓(A卷-中檔卷)解析版
- 網絡成癮干預機制-洞察及研究
- 疏通經絡課件
- 2025-2030年中國3C數碼充電器行業市場深度調研及市場供需與投資價值研究報告
- 2026屆云南三校高考備考聯考卷(一)化學試卷+答案
- 2024中國農業銀行分行年度營銷宣傳方案
- 2025年高考全國一卷寫作范文10篇
- 高三第一學期的班主任工作總結
- 汽車司機宿舍管理制度
- 物業監控調取管理制度
評論
0/150
提交評論