Typescript-03-基礎(chǔ)數(shù)據(jù)類型二-枚舉數(shù)據(jù)類型

枚舉數(shù)據(jù)類型

  • 枚舉數(shù)據(jù)類型是TypeScript對JavaScript的數(shù)據(jù)結(jié)構(gòu)的拓展屈藐,在原生的JavaScript中是不存在枚舉數(shù)據(jù)類型的奈梳,枚舉數(shù)據(jù)用于表示固定的幾個變量飘蚯,只要外部的變量使用了定義好的枚舉數(shù)據(jù)睁本,那么這個外部的變量的值只能在該枚舉數(shù)據(jù)中選擇

  • 通過enum關(guān)鍵字定義枚舉數(shù)據(jù)

  • enum 數(shù)據(jù)名稱 { 變量名稱1, 變量名稱2 }

    enum Gender {
        Male,
        Femal    
    }
    
    // 外部變量綁定枚舉數(shù)據(jù)
    let value1:Gender
    let value2:Gender
    
    // 對外部變量進(jìn)行初始化
    value1 = Gender.Male
    value2 = Gender.Femal
    
    console.log(value1) // 0
    console.log(value2) // 1
    
  • 外部變量綁定枚舉數(shù)據(jù)檀葛,那么外部變量的值只能在該枚舉數(shù)據(jù)中選擇队丝,否則編譯器就會報(bào)錯

    enum Gender {
        Male,
        Femal    
    }
    
    let val:Gender;
    val = 'abc'; // 編譯器報(bào)錯
    
  • 枚舉數(shù)據(jù)中的變量底層本質(zhì)其實(shí)就是數(shù)字類型靡馁,從上至下開始,默認(rèn)是從0開始遞增的

    enum Gender {
        Male,
        Female,
        Simon
    }
    
    console.log(Gender.Male); // 0
    console.log(Gender.Female); // 1
    console.log(Gender.Simon); // 2
    
  • 雖然枚舉數(shù)據(jù)中的變量值默認(rèn)是從0開始遞增的机久,但是我們也可以手動的指定某個枚舉變量的值臭墨,如果手動指定了某個枚舉變量的值,那么后面枚舉變量的值就會根據(jù)上面鄰近的被修改過的枚舉變量的取值進(jìn)行遞增

    enum letter {
        a,
        b,
        c = 6,
        d,
        e,
        f = 14,
        g,
        h,
    }
    
    console.log(letter.a); // 0
    console.log(letter.b); // 1
    console.log(letter.c); // 6
    console.log(letter.d); // 7
    console.log(letter.e); // 8
    console.log(letter.f); // 14
    console.log(letter.g); // 15
    console.log(letter.h); // 16
    
  • 可以通過枚舉變量的名稱拿到它對應(yīng)的取值膘盖,也可以通過它對應(yīng)的取值拿到它的枚舉變量的名稱胧弛,這是就是反向映射

    enum Gender {
        Male = 4,
        Female,
        Simon = 8
    }
    
    console.log(Gender.Male); // 4
    console.log(Gender[4]); // Male
    console.log(Gender.Female); // 5
    console.log(Gender[5]); // Female
    console.log(Gender[8]); // Simon
    
  • 因?yàn)槊杜e數(shù)據(jù)中變量的底層實(shí)現(xiàn)的本質(zhì)是數(shù)字類型,所以外部雖然綁定了該枚舉數(shù)據(jù)侠畔,但是外部變量隨機(jī)賦值一個數(shù)字類型的取值依然不會報(bào)錯

    enum Gender {
        Male,
        Female    
    }
    let val:Gender
    val = 6; // 沒有報(bào)錯
    
  • 某個枚舉變量的取值也可以是計(jì)算屬性结缚,如果使用了計(jì)算屬性,那么該計(jì)算屬性后面的枚舉變量的取值必須手動賦值软棺,不然會報(bào)錯

    enum letter {
        a,
        b,
        c = getSum(1, 3), // 可以使用計(jì)算屬性
        d = 5, // 但是計(jì)算屬性之后的枚舉值需要手動賦值红竭,它不能自動計(jì)算,如果不進(jìn)行手動賦值,那么后面的枚舉值不能自動計(jì)算茵宪,編譯器報(bào)錯
        e,
        f,
        g,
        h,
    }
    
    console.log(letter.a); // 0
    console.log(letter.b); // 1
    console.log(letter.c); // 4
    console.log(letter.d); // 5
    console.log(letter.e); // 6
    console.log(letter.f); // 7
    console.log(letter.g); // 8
    console.log(letter.h); // 9
    
    function getSum(a:number, b:number):number {
        return a + b;
    }
    
  • 枚舉數(shù)據(jù)類型底層實(shí)現(xiàn)原理(簡單)

    let Gender;
    (function (Gender) {
     // Gender[key] = value;
        Gender[Gender["Male"] = 0] = "Male";
        Gender[Gender["Femal"] = 1] = "Femal";
    })(Gender || (Gender = {}));
    
    let Gender = {};
    Gender["Male"] = 0;
    Gender[0] = "Male";
    Gender["Femal"] = 1;
    Gender[1] = "Femal";
    
    enum Gender {
        Male,
        Female    
    }
    

枚舉數(shù)據(jù)類型的分類

  • 數(shù)字枚舉數(shù)據(jù):枚舉數(shù)據(jù)中變量的值全部都是由數(shù)字組成的
  • 字符串枚舉數(shù)據(jù):枚舉數(shù)據(jù)中變量的值全部都是由字符串組成的
  • 異構(gòu)枚舉數(shù)據(jù):枚舉數(shù)據(jù)中變量的值全部都是由數(shù)字或者字符串組成的

數(shù)字number枚舉

  • (上面講解的就是數(shù)字枚舉)

  • 數(shù)字枚舉變量的取值除了是通過計(jì)算屬性返回的number數(shù)值最冰,也可以是const定義number數(shù)值,也可以是其它的變量中保存的number數(shù)值

    let arr:any[] = [8, 'b']
    const num = 1
    enum letter {
        a = arr[0], // 其它的變量中保存的number數(shù)值
        b = num, // const定義number數(shù)值
        c = 6,
        d = getSum(5, 5), // 計(jì)算屬性返回的number數(shù)值
        e = 7,
        f,
        g = 100,
        h,
    }
    function getSum(a:number, b:number):number {
        return a + b;
    }
    console.log(letter.a)
    console.log(letter.b)
    console.log(letter.c)
    console.log(letter.d)
    console.log(letter.e)
    console.log(letter.f)
    console.log(letter.g)
    console.log(letter.h)
    

字符串string枚舉

  • 變量的取值不能根據(jù)前面自動計(jì)算稀火,字符串枚舉數(shù)據(jù)的變量應(yīng)該全部手動賦值

    enum Gender {
        Male = "123",
        Female = '456'
    }
    
  • 不能通過變量的值獲取枚舉變量的名稱

    enum Gender {
        Male = "123",
        Female = '456'
    }
    console.log(Gender['123']) // undefined
    console.log(Gender['456']) // undefined
    
  • 變量的取值不能是通過計(jì)算屬性返回的string的數(shù)值暖哨,也不能是通過const定義的string數(shù)值,也不能是其它變量中保存string數(shù)值

    let arr:any[] = [8, 'b']
    const str = 'zs'
    enum letter {
        a = arr[1], // 報(bào)錯
        b = str, // 報(bào)錯
        d = getStr('lnj', '26'), // 報(bào)錯
        e = 'ls',
    }
    function getStr(a:string, b:string):string {
        return a + b;
    }
    console.log(letter.a)
    console.log(letter.b)
    console.log(letter.d)
    console.log(letter.e)
    

異構(gòu)枚舉

  • 枚舉數(shù)據(jù)中的變量取值既包含number類型又包含string類型

    enum Gender {
        Male = 6,
        Female = '456'
    }
    

枚舉數(shù)據(jù)的總結(jié)

  • 其實(shí)在一個枚舉數(shù)據(jù)使用要求中憾股,沒有強(qiáng)調(diào)枚舉數(shù)據(jù)的變量的數(shù)值必須是同一個數(shù)據(jù)類型鹿蜀。也就是說,異構(gòu)枚舉數(shù)據(jù)使用的頻率更高
  • 在對枚舉數(shù)據(jù)的變量進(jìn)行手動賦值過程中服球,如果是賦的值是number類型,那么這個數(shù)值可以是直接定義的number數(shù)值颠焦,也可以是通過計(jì)算屬性得到的number數(shù)值斩熊,也可以是其它變量中保存的number數(shù)值
  • 在對枚舉數(shù)據(jù)的變量進(jìn)行手動賦值過程中,如果是賦的值是string類型伐庭,那么這是數(shù)值只能是直接定義的string數(shù)值粉渠,不能是外部變量或者常量中保存的string數(shù)值
  • 枚舉數(shù)據(jù)中的變量的數(shù)值可以自動計(jì)算,但也只能是計(jì)算number的數(shù)值圾另。它只能根據(jù)上一個的number類型的數(shù)值進(jìn)行計(jì)算霸株,假如上一個不是number的數(shù)值,那么他就無法計(jì)算集乔,需要手動賦值一個number的數(shù)值去件,才能不影響后面的枚舉變量的數(shù)值,這在異構(gòu)枚舉中頗為重要
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末扰路,一起剝皮案震驚了整個濱河市尤溜,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌汗唱,老刑警劉巖宫莱,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異哩罪,居然都是意外死亡授霸,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門际插,熙熙樓的掌柜王于貴愁眉苦臉地迎上來碘耳,“玉大人,你說我怎么就攤上這事腹鹉〔爻” “怎么了?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長愉阎。 經(jīng)常有香客問我绞蹦,道長,這世上最難降的妖魔是什么榜旦? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任幽七,我火速辦了婚禮,結(jié)果婚禮上溅呢,老公的妹妹穿的比我還像新娘澡屡。我一直安慰自己,他們只是感情好咐旧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布驶鹉。 她就那樣靜靜地躺著,像睡著了一般铣墨。 火紅的嫁衣襯著肌膚如雪室埋。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天伊约,我揣著相機(jī)與錄音姚淆,去河邊找鬼。 笑死屡律,一個胖子當(dāng)著我的面吹牛腌逢,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播超埋,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼搏讶,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了纳本?” 一聲冷哼從身側(cè)響起窍蓝,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎繁成,沒想到半個月后吓笙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡巾腕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年面睛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尊搬。...
    茶點(diǎn)故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡叁鉴,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出佛寿,到底是詐尸還是另有隱情幌墓,我是刑警寧澤但壮,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站常侣,受9級特大地震影響蜡饵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜胳施,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一溯祸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧舞肆,春花似錦焦辅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至哩盲,卻和暖如春仆抵,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背种冬。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留舔糖,地道東北人娱两。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像金吗,于是被迫代替她去往敵國和親十兢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容