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

LoginModelRegisterModel

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码。
 

你可能感兴趣的:(domain)