ASP.NET MVC把數(shù)據(jù)庫(kù)中枚舉項(xiàng)的數(shù)字轉(zhuǎn)換成文字
標(biāo)題可能無(wú)法表達(dá)我的本意。比如,有這樣一個(gè)枚舉:
public enum MyChoice { MyFirstChoice = 0, MySecondChoice =1, MyThirdChoice = 2 }
數(shù)據(jù)庫(kù)中,某表某字段保存值為"0,1,2",在顯示的時(shí)候,我們希望是"第一個(gè)選擇,第二個(gè)選擇,第三個(gè)選擇"。如何做呢?
可以為枚舉項(xiàng)上面標(biāo)注自定義特性。先自定義一個(gè)特性如下:
public class EnumDisplayNameAttribute : Attribute { private string _displayName; public EnumDisplayNameAttribute(string displayName) { _displayName = displayName; } public string DisplayName { get { return _displayName; } } }
然后,把自定義特性標(biāo)注放到枚舉項(xiàng)上去。
public enum MyChoice { [EnumDisplayName("我的第一個(gè)選擇")] MyFirstChoice = 0, [EnumDisplayName("我的第二個(gè)選擇")] MySecondChoice =1, [EnumDisplayName("我的第三個(gè)選擇")] MyThirdChoice = 2 }
現(xiàn)在,需要一個(gè)幫助方法,能讀出枚舉項(xiàng)上的自定義特性EnumDisplayName。
public class EnumExt { /// <summary> /// 獲取枚舉項(xiàng)的注釋 /// </summary> /// <param name="e">枚舉項(xiàng)</param> /// <returns></returns> public static string GetEnumDescription(object e) { //獲取枚舉項(xiàng) Type t = e.GetType(); //獲取枚舉項(xiàng)的字段 FieldInfo[] fis = t.GetFields(); foreach (FieldInfo fi in fis) { //如果當(dāng)前字段名稱(chēng)不是當(dāng)前枚舉項(xiàng) if (fi.Name != e.ToString()) { continue;//結(jié)束本次循環(huán) } //如果當(dāng)前字段的包含自定義特性 if (fi.IsDefined(typeof (EnumDisplayNameAttribute), true)) { //獲取自定義特性的屬性值 return (fi.GetCustomAttributes(typeof(EnumDisplayNameAttribute), true)[0] as EnumDisplayNameAttribute).DisplayName; } } return e.ToString(); } public static List<SelectListItem> GetSelectList(Type enumType) { List<SelectListItem> selectList = new List<SelectListItem>(); //selectList.Add(new SelectListItem{Text = "--請(qǐng)選擇--",Value = ""}); foreach (object e in Enum.GetValues(enumType)) { selectList.Add(new SelectListItem { Text = GetEnumDescription(e), Value = ((int)e).ToString() }); } return selectList; } }
以上,
GetEnumDescription方法根據(jù)枚舉項(xiàng)獲取其上的自定義特性EnumDisplayNameAttribute的DisplayName屬性值。
GetSelectList方法根據(jù)枚舉的Type類(lèi)型返回SelectListItem集合,通常在ASP.NET MVC中使用。
最后,就能實(shí)現(xiàn)本篇的需求:
static void Main(string[] args) { string myChoiceInt = "0,1,2"; string[] choiceArr = myChoiceInt.Split(","); string temp = string.Empty; foreach (string item in choiceArr) { //轉(zhuǎn)換成枚舉的類(lèi)型 short enumValShort = short.Parse(item); temp = temp + EnumExt.GetEnumDescription((MyChoice)enumValShort) + ","; } Console.WriteLine(temp.Substring(0, temp.Length - 1)); Console.ReadKey(); }
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章:
1. jsp實(shí)現(xiàn)textarea中的文字保存換行空格存到數(shù)據(jù)庫(kù)的方法2. ASP.NET MVC使用異步Action的方法3. ASP.NET MVC通過(guò)勾選checkbox更改select的內(nèi)容4. django inspectdb 操作已有數(shù)據(jù)庫(kù)數(shù)據(jù)的使用步驟5. Python 操作 MySQL數(shù)據(jù)庫(kù)6. Django生成數(shù)據(jù)庫(kù)及添加用戶報(bào)錯(cuò)解決方案7. 為PHP模塊添加SQL SERVER2012數(shù)據(jù)庫(kù)的步驟詳解8. PHP數(shù)據(jù)庫(kù)抽象層之PDO(一)——簡(jiǎn)介和安裝配置9. ajax動(dòng)態(tài)查詢數(shù)據(jù)庫(kù)數(shù)據(jù)并顯示在前臺(tái)的方法10. PHP完美結(jié)合MYSQL數(shù)據(jù)庫(kù)記錄分頁(yè)顯示
