.NET MVC4 实训记录之三(EntityFramework 与枚举)

  EntityFramework对枚举的引入是从版本5开始的(如果没有记错的话)。枚举可以很大程度上提高对程序的可读性。那么在EntityFramework的CodeFirst模式下,如何使用枚举呢?答案很简单:还是那么用!

  看似废话,其实不然,看下面(修改上一篇中用户信息定义):

 1     /// <summary>

 2     /// 性别枚举

 3     /// </summary>

 4     public enum Gender

 5     {

 6         Male,

 7         Female

 8     }

 9 

10     public class UserProfile

11     {

12         [Key]

13         [DatabaseGenerated(DatabaseGeneratedOption.Identity)]

14         [Column(Order = 0)]

15         public int UserId { get; set; }

16 

17         [Column(Order = 1)]

18         [Required]

19         public string UserName { get; set; }

20 

21         [Column(Order = 2)]

22         public string UserCode { get; set; }

23 

24         [Column(Order = 3)]

25         public int Status { get; set; }

26 

27         [Column(Order = 4)]

28         public string Email { get; set; }

29 

30         [Column(Order = 5)]

31         public Gender Gender { get; set; }

32 

33         [Column(Order = 6)]

34         public int? CreatorId { get; set; }

35 

36         public virtual ICollection<Role> Roles { get; set; }

37 

38         public int? AddressId { get; set; }

39 

40         [ForeignKey("AddressId")]

41         public Address Address { get; set; }

42 

43         public UserProfile()

44         {

45             Gender = Framework.DomainModels.Gender.Male;

46         }

47     }
View Code

 

  删除旧的数据库,重新运行项目,看看会有什么结果!

  好像没什么变化?--------确实没有什么变化!别着急,继续往下看!

  在AccountController中新增修改用户的Action,添加用户编辑视图。

/*  加载编辑页面的Action   */

        public ActionResult EditUser(int id)

        {

            var model = BaseService.GetSingle<UserProfile>(id);     //按照ID获取用户数据

            return View(model);

        }





/*  编辑页面视图  */

@model Framework.DomainModels.UserProfile

@{

    ViewBag.Title = "EditUser";

}



<h2>EditUser</h2>

@using (Html.BeginForm())

{

    @Html.EditorForModel();

}
View Code

  运行你的项目,输入连接http://localhost:****/Account/EditUser/1看看结果(注意,最后一个1是你已经注册的某个用户的ID,前提是你的路由配置要支持这种访问。其实就是创建项目时的默认路由配置)。

  

  OK,枚举变量名已经显示,并非我们在数据库中看到的Int型的值。EF还是比较聪明的。其实这个字段应该显示为一个下拉列表,而并非文本框才最合理。

  一些思考:对于项目而言,并非是所有可以分类的字段都适合使用枚举类型。例如用户状态Status字段,我们可以用数字0表示用未激活,1表用户已激活。为使我们的代码开起来很优雅,然后就用枚举类型描述这个字段。当然这样做没有错,但是如果考虑到扩展性的话,这样做就是一个硬伤。假如我给用户状态增加一个“锁定”,表示用户已经登录,不能再在其它地方登录的话,就必须修改我们的枚举定义。那么这种情况下,建议还是使用普通的Int型(或字符型)字段比较好。虽然我们需要做一些判断将用户可读懂的状态信息显示,但比起修改类型定义带来的好处更多。往后我们还会继续讨论,如何让代码自动识别这些Int型(或字符型)的字段,将可读性更高的信息展示给用户(我自己都很期待噢)。

你可能感兴趣的:(framework)