• MVC 元数据验证


    ASP.NET MVC 3 Validation - 正则表达式验证RegularExpressionAttribute之日期验证
    http://blog.csdn.net/jackvs/article/details/6701186

    C#中Dictionary的用法
    http://jingyan.baidu.com/article/9989c7460ab872f648ecfeed.html

    String.Format格式说明
    http://www.cnblogs.com/tuyile006/archive/2006/07/13/449884.aspx

     
    《Pro ASP.NET MVC 3 Framework》学习笔记之三十一 【模型验证】
    http://www.cnblogs.com/mszhangxuefei/archive/2012/05/28/mvcnotes_31.html

    HTML5 Form Validation Examples
    http://www.the-art-of-web.com/html/html5-form-validation/


    jQuery Validation Plugin
    http://www.the-art-of-web.com/html/html5-form-validation/

    1.ModelState.IsValid用来判断model是否通过验证,前台显示如下
    @Html.ValidationSummary()
    @Html.ValidationMessageFor(model => model.TestName)

    2.ModelState 是个Dictionary类型

    ModelState.AddModelError("testName","* Test Name is not valid.");
    ModelState["TestName"].Errors.Count()

    3.DateTime
    [DataType(DataType.DateTime,ErrorMessage="Please input date value")]  //  ErrorMessage is not valid
     public DateTime TestTime { get; set; }

    DataType后边的Error Message不起作用,不能覆盖生成元素的data-val-date/data-val-number属性,可能对于特殊字符串email,url类型的比较有用

    [Required(ErrorMessage = "Please input a date value")]  也无效

    [RegularExpression(@"^(?:(?!0000)[0-9]{4}(-|/)(?:(?:0[1-9]|1[0-2])(-|/)(?:0[1-9]|1[0-9]|2[0-8])|(?:0[13-9]|1[0-2])(-|/)(?:29|30)|(?:0[13578]|1[02])-31)|(?:[0-9]{2}(?:0[48]|[2468][048]|[13579][26])|(?:0[48]|[2468][048]|[13579][26])00)-02-29)(s+([01][0-9]|2[0-3]):[0-5][0-9]:[0-5][0-9])?$", ErrorMessage = "Please input a date(YYYY/MM/DD) value")]  有效

    但这样比较累赘,还有个简单替换生成元素属性的方法,将-替换成_就可以代替自动生成的信息了
    @Html.TextBoxFor(m => m.Test, new { @data_val_date="please input a valid date"})
    这样我们可以直接添加下列属性来实现客户端的认证
    data_val_number,data_val_date
    data_val_email  无效
    data_val_required
    data-val-regex-pattern,data-val-regex
    data-val-length-min,data-val-length-max,data-val-length
    data-val-range-min,data-val-range-max,data-val-range
    data-val-remote-url,data-val-remote-type,data-val-remote-additionalfields,data-val-remote   无效

    有的时候很奇怪,只对@Html.EditorFor(m => m.Test)有效,却对@Html.TextBoxFor(m => m.Test)无效,属性不能正确生成

    [DisplayFormat(DataFormatString = "{0:d}", ApplyFormatInEditMode = true)]
    这种写法只对@Html.DisplayFor(mbox=>mbox.Test)和@Html.EditorFor(mbox=>mbox.Test)才有效,
    对于@Html.LabelFor(mbox=>mbox.Test)和@Html.TextBoxFor(mbox=>mbox.Test)无效

    4.String
    [Display(Name = "Test Name")]
    [Required(ErrorMessage = "Please input the test name.")]
    [StringLength(10,ErrorMessage="The length can't longer than 10")]
    [StringLength(10, MinimumLength=3)]
    [RegularExpression(@"([a-g])*", ErrorMessage = "Please input valid character")]
    public string TestName { get; set; }

    <input name="Test Name" class="text-box single-line" id="Test" type="text" data-val="true" data-val-regex-pattern="([a-g])*" data-val-regex="valid character" data-val-length-min="3" data-val-length-max="10" data-val-length="length should be 3~10" value=""/>

    [DataType(DataType.Password)]
    public string Test { get; set; }
    <input name="Test" class="text-box single-line valid" id="Test" type="password" value=""/>

    5.Number
    [Range(1, 100, ErrorMessage = "Please input 1~100.")]
    public int Test { get; set; }

    <input name="Test" class="text-box single-line" id="Test" type="number" data-val-required="Test is required" data-val="true" data-val-number="Test is not a valid number" data-val-range-min="1" data-val-range-max="100" data-val-range="input 1~100" value="0"/>

    6.Enum Type
    public enum eReorderLvl
            {
                five = 5,
                ten = 10
            }
    [EnumDataType(typeof(eReorderLvl), ErrorMessage = "Please input 5,10")]
            public int Test { get; set; }


     7.Bool
    [Range(typeof(bool), "true", "true", ErrorMessage="你必须接受条款")]
    public bool TermsAccepted { get; set; }

     
    <input name="Test" class="check-box" id="Test" type="checkbox" data-val-required="Test is required" data-val="true" data-val-range-min="True" data-val-range-max="True" data-val-range="must true" value="true"/>

    8.以上是属于System.ComponentModel.DataAnnotations,也可以实时验证,使用System.Web.Mvc.RemoteAttribute

    [Remote("CheckIfExist", "TestName", HttpMethod = "POST", AdditionalFields = "TestId", ErrorMessage = "Test Name already exists.")]
     public string TestName { get; set; }

    <input name="TestName" class="required" id="TestName" type="text" data-val="true" data-val-remote-url="/Test/CheckIfExist" data-val-remote-type="POST" data-val-remote-additionalfields="*.TestName,*.TestId" data-val-remote="Test Name already exists" data-fieldname="TestName" value="aaa"/>

    9.如果想为基本的类型也在客户端实时验证,可以使用
    jquery.unobtrusive-ajax.js
    jquery.validate.js
    Jquery.validate.unobtrusive.js

        <appSettings>
            ...
            <add key="ClientValidationEnabled" value="true" />
            <add key="UnobtrusiveJavaScriptEnabled" value="true" />
        </appSettings>

  • 相关阅读:
    自身哲学
    horovod
    nvidia-smi 关键知识
    7.22实习培训日志-JSP Servlet
    7.20实习培训日志-Java基础程序设计结构
    7.19实习培训日志- java进阶
    7.18实习培训日志-环境配置与设计模式
    7.17实习培训日志-java基础
    7.10实习培训日志-Maven 敏捷编程
    7.15实习培训日志 java题解
  • 原文地址:https://www.cnblogs.com/sui84/p/6777177.html
Copyright © 2020-2023  润新知