百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>html5教程> ASP.NET MVC 三层合作-数据验证
分享文章到:

ASP.NET MVC 三层合作-数据验证

发布时间:09/01 来源:未知 浏览: 关键词:
第一我们在M层创立一个类:

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Web;
namespace WebApplication1.Models
{
    public class GuestResponse
    {
        //数据验证,必填项,假如不填ErrorMessage 请输入你的会员名
        [Required(ErrorMessage = "请输入你的会员名!")]
        public string Name { get; set; }
        //同上
        [Required(ErrorMessage = "请输入邮箱")]
        //正则表达式,推断可否是邮箱格局
        [RegularExpression(".+\\@.+\\..+",
        ErrorMessage = "请输入准确的邮箱格局")]
        public string Email { get; set; }
        //同上
        [Required(ErrorMessage = "请输入你的手机号码")]
        public string Phone { get; set; }
        public bool? WillAttend { get; set; }
    }
}

代码中已有注释,不多说。

下面,V层:

@model WebApplication1.Models.GuestResponse
@{
    Layout = null;
}
<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>RsvpForm</title>
</head>
<body>
    @using (Html.BeginForm())
    {
        @Html.ValidationSummary()
        <p>Your name: @Html.TextBoxFor(x => x.Name) </p>
        <p>Your email: @Html.TextBoxFor(x => x.Email)</p>
        <p>Your phone: @Html.TextBoxFor(x => x.Phone)</p>
        <p>
            Will you attend?
            @Html.DropDownListFor(x => x.WillAttend, new[] {
            new SelectListItem() {Text = "Yes, I'll be there",
            Value = bool.TrueString},
            new SelectListItem() {Text = "No, I can't come",
            Value = bool.FalseString}
            }, "Choose an option")
        </p>
        <input type="submit" value="Submit RSVP" />
    }
</body>
</html>

这里留意第一行,

@model WebApplication1.Models.GuestResponse

我们绑定我们写的数据类,这样我们才能顺利创立表单。

然后是C层:

 [HttpGet]
        public ViewResult RsvpForm() {
            return View();
        }
        [HttpPost]
        public ViewResult RsvpForm(GuestResponse model)
        {
            if (ModelState.IsValid)
            {
                // TODO: Email response to the party organizer
                return View("Thanks", model);
            }
            else
            {
                // there is a validation error
                return View();
            }
        }

这里我们有两个RsvpForm,我们在上面增加提交方式,离别是Get和Post

if (ModelState.IsValid)

可否通过数据验证,通过返回视图Thanks,且把表单传过来的值传给Thanks视图

数据验证不通过,返回原视图,

这里留意V层

 @Html.ValidationSummary()

增加这句话,在数据验证的时候,数据不通过,视图层才能显示我们的错误提醒信息。

运转截图演示:

我们只输入了姓名,其他没有输入,提醒错误信息

我们输入一个准确的:


然后点击,调到Thanks视图,Thanks视图代码如下:

@model WebApplication1.Models.GuestResponse

@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Thanks</title>
</head>
<body>
    <p> 
        <h1>Thank you, @Model.Name!</h1>
        @if (Model.WillAttend == true)
        {
            @:It's great that you're coming. The drinks are already in the fridge!
}
        else
        {
            @:Sorry to hear that you can't make it, but thanks for letting us know.
}
    </p>
</body>
</html>

这里留意,我们也要绑定我们写的模型类:


 @Model.Name

我们输入的姓名


Model.WillAttend == true

我们输入的值,像传其他,跟这样相似。

结果截图:


至此,我们的MVC三层合作,数据验证,完成!

本文讲解了ASP.NET MVC 三层合作-数据验证,更多相关内容请关注百分百源码网。

相关引荐:

简易 PHP+MySQL 分页类

两个不消递归的树形数组结构函数

HTML转Excel,并实现打印,下载功效

以上就是ASP.NET MVC 三层合作-数据验证的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有153人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板