DDD~我们应该知道的Model,DomainModel和ViewModel
图在前
目前项目中可能出现的三种Model模式,对于我们现在开发的一个项目,我觉得使用DDD的思想来设计模型比较清晰,使用DDD的思想把模型model分成了如下三种:
下面是我微博中的截图:
上面的图中把模型分成了ViewModel,它与页面相关,DomainModel,它与业务模块相关,Model,它与数据库相关,它是对数据表的一种映射,一般用XML来表示。
文字说明在后
下面我们来举个例子,用认识一下这三个模型:
下面以用户业务为例,来讲一个这三种模型
UserDomainModel
public class UserDomainModel { [Required] [Display(Name = "用户名")] public string UserName { get; set; } [Required] [DataType(DataType.EmailAddress)] [Display(Name = "电子邮件地址")] public string Email { get; set; } public int UserID { get; set; } public Common_Area Common_Area{get;set;} public User_Extension User_Extension{get;set;} }
而对于用户业务它又有注册,登陆,这需要不同的view来呈现,这时需要ViewModel
LoginModel和RegisterModel
public class LoginModel { [Required] [Display(Name = "用户名")] public string UserName { get; set; } [Required] [DataType(DataType.Password)] [Display(Name = "密码")] public string Password { get; set; } [Display(Name = "记住我?")] public bool RememberMe { get; set; } } public class RegisterModel { [Required] [Display(Name = "用户名")] public string UserName { get; set; } [Required] [StringLength(100, ErrorMessage = "{0} 必须至少包含 {2} 个字符。", MinimumLength = 6)] [DataType(DataType.Password)] [Display(Name = "密码")] public string Password { get; set; } [DataType(DataType.Password)] [Display(Name = "确认密码")] [Compare("Password", ErrorMessage = "密码和确认密码不匹配。")] public string ConfirmPassword { get; set; } }
而这些数据如何与数据库关联,这会用到了model,即我们的表,对于用户业务来说,它可以有user_info,user_Extesion,Common_area等model组成,而domain model是将这三张表进行组合,以user_info为主导,其它两个表于辅助,形式一个整体,而这个
整体我们在DDD里叫它聚合,整理里的标识叫它聚合根,一般是一个Guid码。