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

怎樣用JS模擬實現(xiàn)枚舉

 更新時間:2021年04月28日 10:54:57   作者:淺笑·  
這篇文章主要介紹了怎樣用JS模擬實現(xiàn)枚舉,對枚舉感興趣的同學(xué),可以實驗一下

前言

在當前的JavaScript中,并沒有枚舉這個概念,在某些場景中使用枚舉更能保證數(shù)據(jù)的正確性,減少數(shù)據(jù)校驗過程,下面就介紹一下JavaScript如何模擬實現(xiàn)枚舉效果。

枚舉主要特點

  • 枚舉值不能重復(fù)
  • 不能被修改

實現(xiàn)

let days;
(function (days) {
    days[days["Sunday"] = 0] = "Sunday";
    days[days["Monday"] = 1] = "Monday";
    days[days["Tuesday"] = 2] = "Tuesday";
    days[days["Wednesday"] = 3] = "Wednesday";
    days[days["Thursday"] = 4] = "Thursday";
    days[days["Friday"] = 5] = "Friday";
    days[days["Saturday"] = 6] = "Saturday";
})(days || (days = {}));

這個時候days對象基本實現(xiàn)了枚舉效果,可以通過枚舉值或索引去訪問days對象,但枚舉有個重要特別是不能被修改,這個時候days是可以隨意修改的;可以通過Object.freeze函數(shù)讓對象不改修改,重新導(dǎo)出一個不可以修改的對象,完整代碼如下:

let days;
(function (days) {
    days[days["Monday"] = 1] = "Monday";
    days[days["Tuesday"] = 2] = "Tuesday";
    days[days["Wednesday"] = 3] = "Wednesday";
    days[days["Thursday"] = 4] = "Thursday";
    days[days["Friday"] = 5] = "Friday";
    days[days["Saturday"] = 6] = "Saturday";
    days[days["Sunday"] = 0] = "Sunday";
})(days || (days = {}));

//導(dǎo)出可枚舉對象
export EnumWeek = Object.freeze(days)

以上就是怎樣用JS模擬實現(xiàn)枚舉的詳細內(nèi)容,更多關(guān)于JS的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JavaScript剩余操作符Rest Operator詳解

    JavaScript剩余操作符Rest Operator詳解

    在本篇文章里小編給各位分享的是關(guān)于JavaScript剩余操作符Rest Operator知識點用法總結(jié),有需要的朋友們跟著學(xué)習(xí)下。
    2019-07-07
  • 詳解TypeScript的基礎(chǔ)類型

    詳解TypeScript的基礎(chǔ)類型

    這篇文章主要為大家介紹了TypeScript的基礎(chǔ)類型,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • 微信小程序加載機制及運行機制圖解

    微信小程序加載機制及運行機制圖解

    這篇文章主要介紹了微信小程序加載機制及運行機制圖解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • js查錯流程歸納

    js查錯流程歸納

    歸納是為了更好的理解。平時同事有問題找我?guī)兔鉀Q問題,往往都是很小的問題,這種情況他們并不是缺乏解決問題的知識,而是需要找到問題的辦法
    2012-05-05
  • JS判斷是否長按某一鍵的方法

    JS判斷是否長按某一鍵的方法

    這篇文章主要介紹了JS判斷是否長按某一鍵的方法,涉及JavaScript針對鍵盤按鍵的判斷及響應(yīng)操作技巧,需要的朋友可以參考下
    2016-03-03
  • Bootstrap中的Dropdown下拉菜單更改為懸停(hover)觸發(fā)

    Bootstrap中的Dropdown下拉菜單更改為懸停(hover)觸發(fā)

    在使用bootstrap制作響應(yīng)式導(dǎo)航條時,dropdown組件用的比較多,dropdown默認鼠標左鍵單擊才展開,如果使用鼠標放上去(hover)就展開則會省去點擊時間,這樣能提高效率,下面小編給大家解答下實現(xiàn)思路
    2016-08-08
  • 詳解JavaScript中Proxy與Object.defineProperty的區(qū)別

    詳解JavaScript中Proxy與Object.defineProperty的區(qū)別

    Proxy和Object.defineProperty都是JavaScript中用于實現(xiàn)對象屬性攔截和代理的機制,但它們在功能和應(yīng)用方面有一些區(qū)別,本文通過代碼示例詳細介紹了二者的區(qū)別,感興趣的朋友可以參考下
    2023-06-06
  • JavaScript阻止事件冒泡和默認行為的方法舉例

    JavaScript阻止事件冒泡和默認行為的方法舉例

    JavaScript事件的默認行為指瀏覽器自動執(zhí)行的操作,如鏈接跳轉(zhuǎn)或表單提交,阻止這些行為可以使用event.preventDefault()、return?false或event.returnValue屬性,event.stopPropagation()用于阻止事件傳播,不直接阻止默認行為,需要的朋友可以參考下
    2024-10-10
  • 微信小程序頁面?zhèn)鞫鄠€參數(shù)跳轉(zhuǎn)頁面的實現(xiàn)方法

    微信小程序頁面?zhèn)鞫鄠€參數(shù)跳轉(zhuǎn)頁面的實現(xiàn)方法

    這篇文章主要介紹了微信小程序頁面?zhèn)鞫鄠€參數(shù)跳轉(zhuǎn)頁面的實現(xiàn)方法,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • Web制作驗證碼功能實例代碼

    Web制作驗證碼功能實例代碼

    web開發(fā)中,經(jīng)常會使用驗證碼功能,例如登錄、注冊,或其他關(guān)鍵功能之前經(jīng)常會使用。下面通過實例代碼給大家介紹Web制作驗證碼功能實例代碼,感興趣的朋友一起看看吧
    2017-06-06

最新評論