EntityModel、DomainModel和ViewModel代码实例讲解

目前项目中可能出现的三种Model模式,对于我们现在开发的一个项目,我觉得使用DDD的思想来设计模型比较清晰,使用DDD的思想把模型model分成了如下三种:
Model、DomainModel和ViewModel代码实例讲解 - 郁郁 - 郁郁的博客
 上面的图中把模型分成了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码。
 Model、DomainModel和ViewModel代码实例讲解 - 郁郁 - 郁郁的博客

Struts分页讲解代码实例

02-05

rnrnStruts分页讲解与化码实例rnrn分享一下,大家找找错误,提提意见,有用的着的兄弟 ,别忘了顶一下啊,,,rnrn1 建立与你要查询数据库中的表字段相对应的Bean。这部分由我们熟悉的javaBean来充当。并在其中建立数据库查询方法,该方法需要一个ResultSet类型的参数,是一个静态函数,把ResultSet 中的每条记录装添到一个Bean中,然后保存到ArrayList中返回。在本例中为 XueShengBean 。rn2 建立一个页面数据控制器:PageController 传入由上面返回的Arraylist ,当前页 ,返回一个只包含当前页的ArrayListrn3建立控制器组件,这部分由Struts 中的Action来实现。主要负责将实例化数据Bean ,并利用返回的ArrayList对象,接收由视图传递而来的当前页参数。构造PageController,用pc中的方法 来返回一个只包含当前页的ArrayLIst 并放到request 里,发送到视图显示。rn4建立视图组件,这部分由jsp来充当,为了不出现java 代码,我们使用Struts提供的标签库,主要负责从request中取出刚刚放入的对象,而实现分页显示。本例中为show.jsp.rnrnrn 实例代码rnrn1 数据beanrnpackage kaka;rnrnimport java.util.ArrayList;rnimport java.sql.ResultSet;rnimport org.apache.struts.action.ActionMessage;rnimport java.sql.SQLException;rnrnpublic class XueShengBean rn private String xingming;rn private String id;rn private String xingbie;rn private String beizhu;rn private String xuehao;rnrn public XueShengBean() rn rnrn public static ArrayList getArrayList(ResultSet rs) rn ArrayList al = new ArrayList();rnrn try rn while (rs.next()) rnrn XueShengBean xSB = new XueShengBean();rn xSB.setXuehao(rs.getString("xuehao"));rn xSB.setXingming(rs.getString("xingming"));rn xSB.setXingbie(rs.getString("xingbie"));rn xSB.setBeizhu(rs.getString("beizhu"));rn xSB.setId(rs.getString("id"));rnrn al.add(xSB);rnrn rn catch (SQLException ex) rn System.out.println(ex.getMessage() + "读数据时出错");rnrn rnrn return al;rn rn rnrn public void setXingming(String xingming) rn this.xingming = xingming;rn rnrn public void setId(String id) rn this.id = id;rn rnrn public void setXingbie(String xingbie) rn this.xingbie = xingbie;rn rnrn public void setBeizhu(String beizhu) rn this.beizhu = beizhu;rn rnrn public void setXuehao(String xuehao) rn this.xuehao = xuehao;rn rnrn public String getXingming() rn return xingming;rn rnrn public String getId() rn return id;rn rnrn public String getXingbie() rn return xingbie;rn rnrn public String getBeizhu() rn return beizhu;rn rnrn public String getXuehao() rn return xuehao;rn rnrnrnrnrnrn

没有更多推荐了,返回首页