首頁  >  文章  >  web前端  >  javascript模擬枚舉的簡單實例_javascript技巧

javascript模擬枚舉的簡單實例_javascript技巧

WBOY
WBOY原創
2016-05-16 16:56:421383瀏覽

如下,我們來定義Week的列舉:

複製程式碼 程式碼如下:

if(typeof WeekDay == "undefined"){

var WeekDay = {};

WeekDay.Sunday = 0;

WeekDay.Monday = 1;

WeekDay.Tuesday = 2;

WeekDay.Wedesay = 3;

WeekDay.Thursday = 4;

WeekDay.Friday = 5;

WeekDay.Saturday = 6;

}


測試如下:
alert(WeekDay.Monday);  // -----> Output: 1

當然,我們有更直覺的方式。以定義DOM文檔節點類型為例,定義方式如下:

複製程式碼 程式碼如下:

程式碼如下:

程式碼如下:

if(typeof Node == "undefined"){

var Node = {

ELEMENT_NODE: 1,

ATTRIBUTE_NODE: 2,

TEXT_NODE: 3,

CDATA_SECTION_NODE: 4,

ENTITY_REFERENCE_NODE: 5,

ENTITY_NODE: 6,

PROCESSING_INSTRUCTION_NODE: 7,

COMMENT_NODE: 8,

DOCUMENT_NODE: 9,

DOCUMENT_TYPE_NODE: 10,


DOCUMENT_FRAGEMENT_NODE: 11,
NOTATION_NODE: 12 }}測試如下:


複製代碼

代碼如下:

alert(document.nodeType == Node.DOCUMENT_NODE);  // -----> Output: trueIE 說明,以上Node定義可作為修正trueIE支援DOM節點類型常數用(其他主流瀏覽器均支援)。 與類C語言類似,以上2個例子的枚舉對應屬性值均為整形。你可能想到,還能定義成別的類型?要回答這個問題,得先知道咱們這個枚舉實現的原理。前面說到,這裡是用JSON來實現的,而JSON可以使用任何類型的值!所以,Js中的枚舉可以是任何類型的值。以下以String類型為例:

複製程式碼

程式碼如下:

if(type Color = = "undefined"){

var Color = {

Color1: 'red',

Color2: 'green',

Color3: 'white',

Color4: 'black'
}

}檢定如下:alert(Color.Color1); // -----> Output: red 以更為複雜的型別來定義一個PersonList枚舉如下:

複製程式碼

程式碼如下:

if(typeof PersonList == "undefined"){

var PersonList = {

ZhangSan: {

Id: 1,

Name: 'ZhangSan',

Gender: 'man'

},

LiSi: {

Id: 2,

Name: 'LiSi',

Gender: 'woman'

},

ZhaoWu: {

Id: 3,

Name: 'ZhaoWu',
Gender: 'man'

}

}}測試結果如下圖:
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn