MVC模型数据注释demo

一、模型数据注释

  • ASP.NET MVC框架提供了数据验证的API,称为“模型数据注释”或“模型元数据”。
  • 数据验证API位于System.ComponentModel.DataAnnotations名称空间。
数据验证API示例说明
Compare[Compare(“name2”,ErrorMessage =“不一致”)]两个属性值必须一致
Range[Range(1, 20, ErrorMessage = “数字范围1-20”)]数值范围
RegularExpression[RegularExpression(@“正则表达式”+)+$", ErrorMessage =“请输入正确的邮箱地址”)]正则表达式校验
Required[Required(ErrorMessage =“必填项”)]必填
StringLength[StringLength(20,ErrorMessage =“字符范围10-20”,MinimumLength =10)]字符长度

二、demo

2.1 在model添加student类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations;

namespace MyMVCdemo01.Models
{
    public class StudentModel
    {

        [Required(ErrorMessage ="必填项")]
        [StringLength(20,ErrorMessage ="字符范围10-20",MinimumLength =10)]
        public string id { get; set; }
        [Compare("name2",ErrorMessage ="与name2不一致")]
        public string name { get; set; }

        public string name2 { get; set; }
        [StringLength(20, ErrorMessage = "字符范围10-20", MinimumLength = 10)]
        public string class_name { get; set; }

        [RegularExpression(@"^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$", ErrorMessage ="请输入正确的邮箱地址")]
        public string email { get; set; }

        [Range(1, 20, ErrorMessage = "数字范围1-20")]
        public int age { get; set; }

    }
}
2.2 在Index视图添加表达,强类型引用student类型

@model MyMVCdemo01.Models.StudentModel
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
</head>
<body>
    @using (Html.BeginForm("demo2", "Home", FormMethod.Post))
    {
        <table class="table table-bordered">
            <tr>
                <td>ID</td>
                <td>
                    @Html.TextBoxFor(t => t.id)
                </td>
                <td>
                    @Html.ValidationMessageFor(t => t.id)
                </td>
            </tr>
            <tr>
                <td>name</td>
                <td>@Html.TextBoxFor(t => t.name)</td>
                <td>
                    @Html.ValidationMessageFor(t => t.name)
                </td>
            </tr>
            <tr>
                <td>name2</td>
                <td> @Html.TextBoxFor(t => t.name2)</td>
                <td>
                    @Html.ValidationMessageFor(t => t.name2)
                </td>
            </tr>
            <tr>
                <td>class_name</td>
                <td> @Html.TextBoxFor(t => t.class_name)</td>
                <td>
                    @Html.ValidationMessageFor(t => t.class_name)
                </td>
            </tr>
            <tr>
                <td>email</td>
                <td> @Html.TextBoxFor(t => t.email)</td>
                <td>
                    @Html.ValidationMessageFor(t => t.email)
                </td>
            </tr>
            
        </table>
        <input type="submit" class="btn btn-primary"  value="提交"/>
}
</body>
</html>
2.3效果

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值