MVC-------Model层的不可或缺

在做项目中,我们一直使用的是V(View)层和C(Controllers)层,视图的加载,数据的传递,一直都是ViewController在交互,那么 M(Model)层的意义到底在哪???(我们新建一个MVC3.0应用程序)

  1. 我们这里所说的Model层,并不是我们三层设计中所提到的实体。此处的Model层是以能与用户更准确的交互事件为基础建立起来的一种模式。

 public class ChangePasswordModel

    {

        [Required]

        [DataType(DataType.Password)]

        [Display(Name = "当前密码")]

        public string OldPassword { get; set; }

 

        [Required]

        [StringLength(100, ErrorMessage ="{0} 必须至少包含 {2} 个字符。", MinimumLength = 6)]

        [DataType(DataType.Password)]

        [Display(Name = "新密码")]

        public string NewPassword { get; set; }

 

        [DataType(DataType.Password)]

        [Display(Name = "确认新密码")]

       [System.Web.Mvc.Compare("NewPassword", ErrorMessage ="新密码和确认密码不匹配。")]

        public string ConfirmPassword { get;set; }

    }

 

  1. Model的创建过程结合了两者:一者是我们常规中所说的实体,二者是实体的每个属性需要满足的格式,从而与用户进行验证交互。
  1. 那么model层又如何显示到界面上呢??
    1. 新建一个分页视图:引用相应的Model
      1. @model MvcApplication1.Models.RegisterModel

@using(Html.BeginForm()) {

    @Html.ValidationSummary(true,"密码更改不成功。请更正错误并重试。")

    <div>

        <fieldset>

            <legend>帐户信息</legend>

 

            <divclass="editor-label">

                @Html.LabelFor(m =>m.OldPassword)

            </div>

            <divclass="editor-field">

                @Html.PasswordFor(m =>m.OldPassword)

                @Html.ValidationMessageFor(m=> m.OldPassword)

            </div>

 

            <divclass="editor-label">

                @Html.LabelFor(m =>m.NewPassword)

            </div>

            <divclass="editor-field">

                @Html.PasswordFor(m =>m.NewPassword)

                @Html.ValidationMessageFor(m=> m.NewPassword)

            </div>

 

            <divclass="editor-label">

                @Html.LabelFor(m =>m.ConfirmPassword)

            </div>

            <divclass="editor-field">

                @Html.PasswordFor(m =>m.ConfirmPassword)

                @Html.ValidationMessageFor(m=> m.ConfirmPassword)

            </div>

 

            <p>

                <inputtype="submit" value="更改密码" />

            </p>

        </fieldset>

    </div>

}

 

 

 

model层也有一些逻辑判断的内容,所以MVC的逻辑关系分的并不是特别清晰。

一点点小见解!!


评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值