真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

typescript中接口與類的示例分析

小編給大家分享一下typescript中接口與類的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比山亭網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式山亭網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋山亭地區(qū)。費用合理售后完善,10多年實體公司更值得信賴。

為了簡便,把typescript簡寫為ts

接口Interface

可能有些同學(xué)對于接口比較陌生,在弱類型語言的語言層面很難看到它的蹤影,不像強類型語言,語言層面就考慮到了。但在ts世界里,我們就可以看到它的蹤影了,說白了,它只負(fù)責(zé)定義,說明你的對象里面有些什么,也就是結(jié)構(gòu),當(dāng)然,它就不能夠被實例化了。

定義

那么,該如何定義接口呢,當(dāng)然是使用關(guān)鍵字interface

interface IA {
    name: string
}

以上聲明了接口IA,有個屬性name,為字符串型
這樣,我們就可以給一個變量聲明IA類型并賦值初值

var a: IA = {
    name: 'hello'
}

繼承

接口也是可以繼承的,假如你有個IB接口也包含IA的結(jié)構(gòu),就可以簡單的繼承它,并擴展自己的屬性

interface IB extends IA {
    id: number
}

類與接口類似,但它除了定義外,還有實現(xiàn),如給變量賦值,它是可以實例化的

定義

定義的關(guān)鍵字是class,相信熟悉es6的同學(xué)已經(jīng)早就用的習(xí)以為常了

class A {
    a: string = 'xxxxx'
}

以上定義了類A,它有個字符串類型a,同時給它賦了初值xxxxx,這樣我們可以像下面這樣用,實例化它,并可以引用屬性a

var a = new A()
console.log(a.a)

當(dāng)然我們也可以修改屬性a

共有,私有,受保護等成員訪問修飾符

屬性有訪問權(quán)限之分,哪些成員可以訪問,誰可以訪問

public 也就是誰都可以訪問

private 只有內(nèi)部成員可以訪問,說白了,就是自帶的函數(shù)可以訪問

protected 受保護的,除了自己,繼承了該類的都可以訪問

以上關(guān)鍵字一般加在屬性前面,不加的話,就是public

所謂成員,不要僅限于屬性,還包括方法,也叫函數(shù),但是在類中一般都叫方法

class A {
    public a = 'a'
    private b = 'b'
    protected c = 'c'
}

注意,以上聲明的時候沒有給屬性指定類型,這是合法的,因為可以根據(jù)后邊的初值推斷出相應(yīng)的類型

構(gòu)造函數(shù)

說到了類,自然是少不了構(gòu)造函數(shù),這個函數(shù)比較特別,是在實例化的時候調(diào)用的,也就是new的時候;強類型語言中一般都是以類名來命名的一個函數(shù),ts中是以constructor來定義和實現(xiàn)的,當(dāng)然嚴(yán)格來說,是js中是這樣規(guī)定的。
其實構(gòu)造函數(shù)跟普通函數(shù)沒什么區(qū)別,可以有參數(shù),函數(shù)體里面就是實現(xiàn),可以給屬性賦初值等操作,改寫以上A,把給a
即使你定義任何構(gòu)造函數(shù),也會有一個默認(rèn)構(gòu)造函數(shù)的,只是它什么都沒干

class A {
    a: string
    constructor(arg: string) {
        this.a = arg
    }
}

在ts中,構(gòu)造函數(shù)還有個神奇的功能,那就是在構(gòu)造函數(shù)參數(shù)中定義和賦初值,不用在類中重復(fù)聲明,在構(gòu)造函數(shù)中賦初值,如下

class A {
    constructor(public a: string)
}

上面我們就定義了A中的一個字符串屬性a,把構(gòu)造函數(shù)的第一個參數(shù)賦值給它

繼承

跟接口類似,類繼承也是用關(guān)鍵字extends

class B extends A {
    d: number = 1
}

實現(xiàn)接口

類不僅可以繼承已有類,還可以實現(xiàn)接口,要注意的是,接口中的屬性,類中必須有相應(yīng)的實現(xiàn)
實現(xiàn)的關(guān)鍵字是implements

class C implements IA {
    name = 'c'
}

當(dāng)然你可以實現(xiàn)和繼承同時用,也是沒問題的

class D extends A implements IA {
    name = 'd'
}

靜態(tài)成員

普通成員在每個實例中是單獨存在的,而靜態(tài)成員是在類中共享的,也就是只有一份,靜態(tài)成員聲明的方式是使用關(guān)鍵字static

class A {
    static sa = 'nnnn'
}

以上我們就聲明了一個字符串屬性sa,并賦初值nnnn,當(dāng)需要訪問的時候,只要像下面調(diào)用就好了

A.sa

關(guān)于接口與類的東西還挺多的,由于篇幅有限,先到此處吧,更多內(nèi)容,以后在講

看完了這篇文章,相信你對“typescript中接口與類的示例分析”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


分享標(biāo)題:typescript中接口與類的示例分析
文章網(wǎng)址:http://weahome.cn/article/gghojs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部