關(guān)于TypeScript開發(fā)的6六個實用小技巧分享
本文總結(jié)一下使用TypeScript開發(fā)應用程序的一點小經(jīng)驗。說之前,推薦一個VSCODE立即執(zhí)行TS代碼的插件quokka.js,
使用方式,ctrl+shipt+p,輸入關(guān)鍵字quokka
回車之后,輸入代碼之后會立即執(zhí)行
1. 開發(fā)之前確定實體類型
在正式編碼之前,如果沒有接口文檔的話,最好能拿到數(shù)據(jù)字典,根據(jù)數(shù)據(jù)字典定義一下項目中實體類型,例如數(shù)據(jù)字典中有用戶表,企業(yè)表,我們就可以新建一個types文件夾,把對應的類型放到不同的文件中,目錄如下:
types user.ts corp.ts ...
推薦使用interface定義實體類型,比type語義化更好
interface User{ id:string name:string }
2. 請求接口時只需要定義自己需要用到的字段
定義類型時只需要定義自己需要用到的字段,沒用的字段不需要定義。因為后端返回的數(shù)據(jù)是什么類型,需要前端來指定類型然后TS做判斷,如果前端不指定類型,TS根本沒辦法判斷。
例如后端返回的數(shù)據(jù)如下:
user:{ id:1, name:'xiaoming', sex:0 }
定義的類型如下:
interface User{ id:number, name:string }
這種情況下,TS只會檢查user中有沒有id和name,對于sex是忽略的
3. 使用枚舉類型
像性別(男女),管理員類型(超管、普通用戶),會員類型(普通用戶,VIP,超級VIP)這種類型的數(shù)據(jù)結(jié)構(gòu)適合用枚舉類型來定義,枚舉類型也可以作為值來使用。
舉個栗子:
//使用枚舉類型來定義會員類型 enum UserType{ Common=0, VIP=1, SuperVIP=2 } class User{ id:string name:string type:UserType } let userList:User[]=[] userList.push({ id:'001', name:'Jack', type:UserType.SuperVIP //枚舉類型定義的類型可以作為值來使用 })
枚舉類型也可以是字符串,舉例如下,用法同上
enum UserType{ Common='DiaoSi', VIP='LowBVIP', SuperVIP='SuperVIP' }
4. DOM元素的類型要正常給
對于DOM元素,不要給any,人家是有類型的。
一般來說,所有的標簽都繼承自HTMLElement,然后不同標簽有不同的類型,這個類型往往是套路化的,例如video元素的類型就是HTMLVideoElement,div元素的類型是HTMLDivElement,canvas元素的類型是HTMLCanvasElement,以此類推。其實常用的類型并不多,簡單列一下:
let element:HTMLElement=null let video:HTMLVideoElement=null let div:HTMLDivElement=null let canvas:HTMLCanvasElement=null let e:Event =null //事件對象 e.target
一定要給DOM元素類型,這樣你才能收獲代碼提示
這里補充一個上傳文件時類型怎么給,給Input元素綁定了onChange方法,方法如下:
onChange(event: Event): void { if ((event.target as HTMLInputElement).files && (event.target as HTMLInputElement).files.length) { const [file] = event.target.files; } }
5.對象的類型要怎么給
有一個函數(shù),接收對象作為參數(shù),類型要怎么給?
首先,不要給any,不要動不動就給any,較Low,想想對象包含啥,一個key,一個value。key的話肯定是個string類型,value要看具體需求,有可能你的value只能是數(shù)字或者字符串,那就 number|string,如果啥都可以,那就給any吧
//定義對象的類型,key一般是string,value可以按照需求給 interface ObjType{ [key:string]:any } function deepCopy(obj:ObjType){ for(let key in obj){ console.log(obj[key]) } } let obj={name:"Jack"} deepCopy(obj)
6.結(jié)構(gòu)賦值時類型怎么給
你有一個函數(shù),接收一個對象,在對象中對參數(shù)進行解構(gòu),結(jié)構(gòu)得到的對象屬性的類型要怎么給,代碼如下:
const user={ name:'Jack', age:10, friends:[{id:0,name:'Peter',connect:100},{id:1,name:'Alice',connect:69}] } interface Friend{ id:number, name:string, connect:number } function handleFriends({friends}){//friends的類型要怎么給 friends.map(item=>item.connect) }
思考10秒鐘,
10
9
8
7
6
5
4
3
2
1
放答案:
interface Friend{ id:number, name:string, connect:number } function handleFriends({friends}:{friends:Friend[]}){ friends.map(item=>item.connect) }
這種在react hooks用的較多。
總結(jié)
到此這篇關(guān)于TypeScript開發(fā)小技巧分享的文章就介紹到這了,更多相關(guān)TypeScript開發(fā)小技巧內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
動態(tài)調(diào)整textarea中字體的大小代碼
用js批量輸出select事件控制textarea中字體的大小的代碼。2009-12-12微信小程序?qū)崿F(xiàn)文字長按復制與一鍵復制功能全過程
微信小程序開發(fā)是依托微信的,所以他的代碼是嵌入在微信的原始代碼之中的,這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)文字長按復制與一鍵復制功能的相關(guān)資料,需要的朋友可以參考下2023-03-03javascript中日期函數(shù)new Date()的瀏覽器兼容性問題
這篇文章主要介紹了javascript中日期函數(shù)new Date()的瀏覽器兼容性問題,需要的朋友可以參考下2015-09-09