• 处理表单

前面的列子我们已经把表单提交给了HomeControllers类中的RsvpForm动作方法,只是在这个动作方法内,我们并没有做什么具体的逻辑处理,而是直接返回一个

“Thanks”的视图。
 return View("Thanks", studentResponse);
这个View方法的调用告诉MVC,查找并渲染一个名为“Thanks”的视图,并把studentResponse对象传递给视图。现在项目中还没有这个视图,这里创建Thanks视图,怎么创建就不用再说了。如下所示
Thanks视图的代码如下
@model PartyInvites.Models.StudentResponse

@{
Layout = null;
} <html>
<head>
<title>Thanks</title>
</head>
<body>
<p>谢谢您!,@Model.Name!</p>
@if (Model.HavingGet==true)
{
@:很高心您已经收到了录取通知书!
}
else
{
@:不好意思!您还没有收到录取通知书!我们会尽快核对,并通知您!
}
</body>
</html>
这里的Thanks视图使用Razor来显示基于StudentResponse属性的内容,这是我们在RsvpForm动作方法中传递给视图的。Razor的@model操作符指示了这个强类型视图的域模型类型。为了访问这个域对象中某个属性的值,我们使用Model.<属性名>。列如获得Name属性的值,调用Model.Name。这里对Razor语法大家肯定会不熟悉,后面我们在来慢慢研究它。
至此我们可以运行这个程序来看一下结果
  • 添加验证

现在,到了把验证添加到应用程序的时候了。如果不做这件事,用户可能会出入无意义的数据,甚至递交一个空白表单。

在MVC应用程序中,验证被典型地运用于域(模型,MVC中M)模型,而不是在用户界面上。这意味着,在一个地方定义验证条件,会在任何运用模型类的地方生效。ASP.NET MVC支持验证规则声明,验证规则是以System.ComponentModel.DataAnnotations命名空间中的注解属性进行定义的。下面演示了如何把注解的属性运用于StudentResponse模型类。

using System.ComponentModel.DataAnnotations;
namespace PartyInvites.Models
{
public class StudentResponse
{
[Required(ErrorMessage = "请输入您的姓名!")]
public string Name { get; set; }
[Required(ErrorMessage = "请输入您的手机号码!")]
public string Mobile { get; set; }
[Required(ErrorMessage = "请输入您的邮箱!")]
[RegularExpression(".+\\@.+\\..+", ErrorMessage = "邮箱格式不正确!")]
public string Email { get; set; }
[Required(ErrorMessage = "请确定您是否已收到录取通知书!")]
public bool? HavingGet { get; set; }
}
}

如何使用呢?可以在控制器类中使用ModelState.IsValid属性来检查是否有验证问题。如下所示演示了在处理POST的RsvpForm动作方法中如何运用ModelState.IsValid.

[HttpPost]
public ViewResult RsvpForm(StudentResponse studentResponse)
{
if (ModelState.IsValid)
{
//TODO:发送studentResponse 邮件给学校
return View("Thanks", studentResponse);
}
else
{
//有验证错误--重新显示表单
return View();
} }

如果没有验证错误,就会同之前那样,告诉MVC渲染Thanks视图;如果有验证错误,则通过调用不带参数的View方法来重新渲染视图。

我们需要把验证错误信息显示给用户,通过在提交表单的视图中使用Html.ValidationSummary 辅助器方法,如下所示

<body>

@using(Html.BeginForm()){

@Html.ValidationSummary()

<p>您的名字:@Html.TextBoxFor(m => m.Name)</p>
<p>您的邮箱:@Html.TextBoxFor(m => m.Email)</p>

……

}

如果没有错误,这个Html.ValidationSummary方法会在表单中创建一个隐藏的列表条目占位符;否则,MVC会使这个占位符称为可见,并添加由验证注解属性定义的错误消息。如下所示

知道我们用于StudentResponse类的所有验证约束都得到满足,用户才会看到Thanks视图。注意,我们在表单中输入的数据是被保留的,并且,当带有验证摘要的视图被重新渲染时,被再次显示出来(这个有点象传统的ASP.NET Web Form)。这是我们通过模型绑定所得到的好处。

到这里一个简单的小应用程序基本算是完成了。

通过这几课的学习,我们对MVC有了大概的了解。

MVC自学第四课的更多相关文章

  1. MVC自学第三课

    上一课我们已经能够做出简单的HTML显示页面,并懂得了MVC的工作模式,这一课我们讲解一些动态的数据交互. 在MVC中,控制器的工作是构造某些数据,而视图的工作是把它渲染成HTML.数据是从控制器传递 ...

  2. 微信小程序自学第四课:数据绑定

    WXML 中的动态数据均来自对应 Page 的 data. 一.简单绑定 数据绑定使用 Mustache 语法(双大括号)将变量包起来,可以作用于: 1.内容 <view> {{ mess ...

  3. ASP.NET MVC Model验证(四)

    ASP.NET MVC Model验证(四) 前言 本篇主要讲解ModelValidatorProvider 和ModelValidator两种类型的自定义实现,前者是Model验证提供程序,而Mod ...

  4. ASP.NET MVC Model绑定(四)

    ASP.NET MVC Model绑定(四) 前言 前面的篇幅对于Model绑定器IModelBinder以及实现类型.Model绑定器提供程序都作了粗略的讲解,可以把Model绑定器想象成一个大的容 ...

  5. ASP.NET MVC Model元数据(四)

    ASP.NET MVC Model元数据(四) 前言 前面的篇幅讲解了Model元数据生成的过程,并没有对Model元数据生成过程的内部和Model元数据结构的详细解释.看完本篇后将会对Model元数 ...

  6. MVC系列——MVC源码学习:打造自己的MVC框架(四:了解神奇的视图引擎)

    前言:通过之前的三篇介绍,我们基本上完成了从请求发出到路由匹配.再到控制器的激活,再到Action的执行这些个过程.今天还是趁热打铁,将我们的View也来完善下,也让整个系列相对完整,博主不希望烂尾. ...

  7. ASP.NET MVC下的四种验证编程方式[续篇]

    在<ASP.NET MVC下的四种验证编程方式>一文中我们介绍了ASP.NET MVC支持的四种服务端验证的编程方式("手工验证"."标注Validation ...

  8. ASP.NET MVC下的四种验证编程方式

    ASP.NET MVC采用Model绑定为目标Action生成了相应的参数列表,但是在真正执行目标Action方法之前,还需要对绑定的参数实施验证以确保其有效性,我们将针对参数的验证成为Model绑定 ...

  9. MVC学习(四)几种分页的实现(3)

    在这篇MVC学习(四)几种分页的实现(2)博文中,根据URL中传入的两个参数(页码数,首页.上一页.下一页.末页的标记符)来获得对应的分页数据, 只是传入的参数太多,调用起来不太方便(标记符不能够写错 ...

随机推荐

  1. (转)DataTable添加行出现“该行已经属于另一个表”的错误!

    1 DataTable dt1 = new DataTable(); DataTable dt2 = new DataTable(); //为dt1创建结构 DataColumn pName = ne ...

  2. Spring-----Spring对AOP的支持

    转载自:http://blog.csdn.net/hekewangzi/article/details/51713002

  3. [Oracle]ocilib绑定数组实现批量写入

    #include "ocilib.h" #define INSERT_SQL_00 MT("INSERT INTO C_PICRECORD_00 (ID, DEV_ID) ...

  4. $.Event 你不知道的用法

    最近在使用Bootstrap.js,一不小心趴开源码看了一下,尤其是看到tab.js var hideEvent = $.Event('hide.bs.tab', { relatedTarget: $ ...

  5. 关于使用HttpSessionBindingListener获取在线用户数,同一用户登陆一次

    原创地址:http://blog.csdn.net/jiaoxueli/article/details/2226134 考虑到项目中统计在线用户数量和同一用户只能登陆一次的需求,查询联系 HttpSe ...

  6. redBag

    var redBag = (function () { var initialed = false, raining = true, createInterval, walkInterval, cre ...

  7. doT.js 模板引擎的使用

    dot.js是一个模板框架,在web前端使用. dot.js作为模板引擎, 主要的用途就是,在写好的模板上,放进数据,生成含有数据的html代码. 这是很简单的web前端模板框架, 简单说几个东西,你 ...

  8. php pdo mysql数据库操作类

    <?php namespace iphp\core; use iphp\App; /** * 数据库操作基类 基于pdo * @author xuen * 支持链式操作,支持参数绑定 * 说明1 ...

  9. Javascript 之内置对象

    JS提供了11种引用类型:Object.Array.Date.Function.Error.RegExp.Math.Number.String.Boolean.Globle.其中包括了三种基本包装类型 ...

  10. HTTP协议漫谈(转)

    转自:http://www.cnblogs.com/CareySon/archive/2012/04/27/HTTP-Protocol.html HTTP的定义和历史 在一个网络中.传输数据需要面临三 ...