欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于TypeScript開發(fā)的6六個實用小技巧分享

 更新時間:2021年09月03日 11:07:13   作者:_紅領(lǐng)巾  
TypeScript是Javascrip t超集,支持靜態(tài)類型檢測,可以在編譯期提前暴露問題,節(jié)省debug時間,下面這篇文章主要給大家介紹了關(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)文章

最新評論