TypeScript接口/數(shù)組類型/內置對象/函數(shù)類型/類型斷言

接口 interface

在TypeScript中具被,使用接口來定義對象的類型冷冗,對「對象的形狀(Shape)」進行描述

demo
interface Person {
    name: string;
    age: number;
    [index: string]: any; //任意屬性
    sex?: number; // 可選屬性
    // readonly id: number  只讀屬性
    //setNum(x:number):number 定義函數(shù)
}
const person: Person = {name: 'ddd', age: 5 }
//如果是其他的類型會報錯

接口實現(xiàn)類

interface Person {
    name: string;
    age: number;
}
class Person implements Person {
    age: number = 18
    name:string = ''
}
export { Person }
const people = new Person()
people// { age:18, name: ' ' }

接口繼承

interface People extends Person {
    sex: string
}

const p: People = {
    name: 'ddd', age: 22,sex: 'd'
}

數(shù)組類型

「類型 + 方括號」表示法
let arr: number[] = [1,2,3]
數(shù)組泛型
let arr: Array<string> = ['2', 'ewr']

內置對象

JavaScript 中有很多內置對象嫩挤,它們可以直接在 TypeScript 中當做定義好了的類型

ECMAScript 的內置對象
let b: Boolean = new Boolean(1);
let e: Error = new Error('Error occurred');
let d: Date = new Date();
let r: RegExp = /[a-z]/;
DOM 和 BOM 的內置對象
let body: HTMLElement = document.body;
let allDiv: NodeList = document.querySelectorAll('div');
document.addEventListener('click', function(e: MouseEvent) {
  // Do something
});

函數(shù)類型

重載

重載允許一個函數(shù)接受不同數(shù)量或類型的參數(shù)痒钝,作出不同的處理
使用重載

function reverse(x: number): number;
function reverse(x: string): string;
function reverse(x: number | string): number | string {
    if (typeof x === 'number') {
        return Number(x.toString().split('').reverse().join(''));
    } else if (typeof x === 'string') {
        return x.split('').reverse().join('');
    }
}

類型斷言

類型斷言(Type Assertion)可以用來手動指定一個值的類型迅皇。

語法

<string>str

str as string

在他tsx 中只能使用最后一種

聲明文件

declare

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末从铲,一起剝皮案震驚了整個濱河市纫骑,隨后出現(xiàn)的幾起案子蝎亚,更是在濱河造成了極大的恐慌,老刑警劉巖先馆,帶你破解...
    沈念sama閱讀 221,331評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件发框,死亡現(xiàn)場離奇詭異,居然都是意外死亡煤墙,警方通過查閱死者的電腦和手機梅惯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,372評論 3 398
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來仿野,“玉大人铣减,你說我怎么就攤上這事∩柙ぃ” “怎么了徙歼?”我有些...
    開封第一講書人閱讀 167,755評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長鳖枕。 經(jīng)常有香客問我魄梯,道長,這世上最難降的妖魔是什么宾符? 我笑而不...
    開封第一講書人閱讀 59,528評論 1 296
  • 正文 為了忘掉前任酿秸,我火速辦了婚禮,結果婚禮上魏烫,老公的妹妹穿的比我還像新娘辣苏。我一直安慰自己肝箱,他們只是感情好,可當我...
    茶點故事閱讀 68,526評論 6 397
  • 文/花漫 我一把揭開白布稀蟋。 她就那樣靜靜地躺著煌张,像睡著了一般。 火紅的嫁衣襯著肌膚如雪退客。 梳的紋絲不亂的頭發(fā)上骏融,一...
    開封第一講書人閱讀 52,166評論 1 308
  • 那天,我揣著相機與錄音萌狂,去河邊找鬼档玻。 笑死,一個胖子當著我的面吹牛茫藏,可吹牛的內容都是我干的误趴。 我是一名探鬼主播,決...
    沈念sama閱讀 40,768評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼务傲,長吁一口氣:“原來是場噩夢啊……” “哼凉当!你這毒婦竟也來了?” 一聲冷哼從身側響起树灶,我...
    開封第一講書人閱讀 39,664評論 0 276
  • 序言:老撾萬榮一對情侶失蹤纤怒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后天通,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泊窘,經(jīng)...
    沈念sama閱讀 46,205評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,290評論 3 340
  • 正文 我和宋清朗相戀三年像寒,在試婚紗的時候發(fā)現(xiàn)自己被綠了烘豹。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,435評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡诺祸,死狀恐怖携悯,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情筷笨,我是刑警寧澤憔鬼,帶...
    沈念sama閱讀 36,126評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站胃夏,受9級特大地震影響轴或,放射性物質發(fā)生泄漏。R本人自食惡果不足惜仰禀,卻給世界環(huán)境...
    茶點故事閱讀 41,804評論 3 333
  • 文/蒙蒙 一照雁、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧答恶,春花似錦饺蚊、人聲如沸萍诱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,276評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽裕坊。三九已至,卻和暖如春曙求,著一層夾襖步出監(jiān)牢的瞬間碍庵,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工悟狱, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人堰氓。 一個月前我還...
    沈念sama閱讀 48,818評論 3 376
  • 正文 我出身青樓挤渐,卻偏偏與公主長得像,于是被迫代替她去往敵國和親双絮。 傳聞我的和親對象是個殘疾皇子浴麻,可洞房花燭夜當晚...
    茶點故事閱讀 45,442評論 2 359

推薦閱讀更多精彩內容

  • TypeScript接口 接口只讀屬性 使用關鍵字readonly定義只讀的接口屬性 出現(xiàn)錯誤,如下 創(chuàng)建不可修改...
    小小小8021閱讀 660評論 0 5
  • 在這之前囤攀,js開發(fā)的屬性和對象可以隨便增添和刪減软免,靈活度雖然高,也增大了我們開發(fā)的難度焚挠,我們必須時刻清醒的認識每個...
    Zszen閱讀 1,430評論 0 49
  • typescript 檢查變量類型的時候其中采用的一個方法是“鴨子類型判斷法” "所謂鴨子類型判斷法也就是指看起來...
    會飛得鼠閱讀 964評論 0 0
  • TypeScript 的核心原則之一就是類型檢查膏萧,我們可以通過接口來規(guī)范類型,他是具有非常強大的功能的蝌衔。image...
    sunxiaochuan閱讀 461評論 0 0
  • TypeScript的核心原則之一是對值所具有的結構進行類型檢查噩斟。 它有時被稱做“鴨式辨型法”或“結構性子類型化”...
    圓夢人生閱讀 510評論 0 1