zoukankan      html  css  js  c++  java
  • 【ASP.NET】Validation 服务器控件

    Validation 服务器控件

    Validation 服务器控件用于验证输入控件的数据。如果数据未通过验证,则向用户显示错误消息。

    创建 Validation 服务器控件的语法是:

    <asp:control_name id="some_id" runat="server" />
    Validation 服务器控件描述
    CompareValidator 把一个输入控件的值与另一个输入控件或一个固定的值进行对比。
    CustomValidator 允许您编写一个方法,来处理输入值的验证。
    RangeValidator 在两个值的范围内检查输入的值。
    RegularExpressionValidator 确保输入控件的值匹配指定的模式。
    RequiredFieldValidator 是输入控件成为必需(必填)的字段。
    ValidationSummary 显示网页中所有验证错误的报告。
    1. CompareValidator
      1. CompareValidator 控件用于将一个输入控件的值与另一个输入控件的值或常数值进行比较。
      2. 主要属性:
        描述
        ControlToValidate 要验证的控件的 id。
        ControlToCompare 要与所验证的控件进行比较的控件名称。
        Display None - 控件不显示,static静态|显示,Dynamic 动态|显示
        ErrorMessage 当验证失败时,在 ValidationSummary 控件中显示的文本。/或者text
        IsValid 布尔值,指示由 ControlToValidate 指定的控件是否通过验证。
        Operator
        • Equal
        • GreaterThan
        • GreaterThanEqual
        • LessThan
        • LessThanEqual
        • NotEqual
        • DataTypeCheck
        ValueToCompare 用于比较的常数值
        Type
        • Currency
        • Date
        • Double
        • Integer
        • String
      3. 实例:

        添加一个名为CompareValidator.aspx的Web页面,在其中添加一个文本框,用于输入日期,要求输入的日期必须是一个当前日期以后的日期,使用CompareValidator控件来验证文本框的输入。    

      4. 代码:
        <form id="form1" runat="server">
                <div>
                    <br />
                    输入日期:<asp:TextBox ID="TextBox1" runat="server" TextMode="Date"></asp:TextBox>
                    <asp:CompareValidator ID="CompareValidator1" runat="server" ControlToValidate="TextBox1" ValueToCompare="2018/12/11" Type="Date" Operator="GreaterThan"  Display="Dynamic" ErrorMessage="日期必须在今天以后"></asp:CompareValidator>
                    <br />
                </div>
            </form>
    2. CustomValidator

      1. CustomValidator 控件允许您书写处理输入值验证的方法。
      2. 属性:
        属性 描述
        ClientValidationFunction 规定要被执行的客户端脚本函数的名称。
        OnServerValidate 规定被执行的服务器端验证脚本函数的名称。
      3. 实例

        添加一个名为CustomValidator.aspx的Web页面,编写自定义验证控件的验证代码用于验证输入的正整数是素数。

      4. 代码:
        <form id="form1" runat="server">
                <div>
                    输入一个整数:<asp:TextBox ID="TextBox1" runat="server" TextMode="Number"></asp:TextBox>
                    <asp:CustomValidator ID="CustomValidator1" runat="server" ErrorMessage="不是素数" ContrlToValidate="TextBox1" OnServerValidate="CustomValidator1_ServerValidate"></asp:CustomValidator>
                    <br />
                    <asp:Button ID="Button1" runat="server" Text="确定" />   
                </div>
            </form>
        protected void CustomValidator1_ServerValidate(object source, ServerValidateEventArgs e)
                {
                    int i;
                    int n = int.Parse(TextBox1.Text);
                    for( i = 2; i <n; i++)
                    {
                        if (n % i == 0)
                        {
                            break;
                        }
                    }
                    if (i >= n)
                        e.IsValid = true;
                    else e.IsValid = false;
                }
    3. RangeValidator
      1. RangeValidator 控件用于检测用户输入的值是否介于两个值之间。可以对不同类型的值进行比较,比如数字、日期和字符。
      2. 属性:
        属性 描述
        MaximumValue 规定输入控件的最大值。
        MinimumValue 规定输入控件的最小值。
      3. 实例:

        添加一个名为RangeValidator.aspx的Web页面,在其中添加一个“考生年龄”的输入文本框,要求输入的值必须在18到80之间,使用RangeValidator控件验证用户在文本框中输入的内容是否在有效范围内。

      4. 代码:
        <form id="form1" runat="server">
                <p>
                    考生年龄:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
                    <asp:RangeValidator ID="RangeValidator1" runat="server" ControlToValidate="TextBox1" MaximumValue="80" MinimumValue="18" Type="Integer"  Text="在18-80之间" ErrorMessage ="必须在18-80之间"></asp:RangeValidator>
                <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="确定" />
                </p>
            </form>
    4. RegularExpressionValidator
      1. RegularExpressionValidator 控件用于验证输入值是否匹配指定的模式。
      2. 主要属性:
        属性 描述
        ValidationExpression 规定验证输入控件的正则表达式。
      3. 实例:验证

        固定电话 (区号-电话号)

         Email( someone@domain.com)1129875586@qq.com

      4. 代码:
         电子邮箱:<asp:TextBox ID="TextBox7" runat="server"></asp:TextBox>
                    <asp:RegularExpressionValidator ID="RegularExpressionValidator4" ControlToValidate ="TextBox7" ValidationExpression=".{1,}@.{3,}" runat="server" ErrorMessage="电子邮件的格式不正确"></asp:RegularExpressionValidator>
        <asp:Label ID="Label1" runat="server" Text="固定电话"></asp:Label><asp:TextBox ID="TextBox4" runat="server"></asp:TextBox>
                    <asp:RegularExpressionValidator ID="RegularExpressionValidator3" runat="server" ControlToValidate="TextBox4" ValidationExpression="\(\d{3}\)\s\d{3}-\d{4}" ErrorMessage="电话形式为XXX-XXXXX"></asp:RegularExpressionValidator>
    5. RequiredFieldValidator
      1. RequiredFieldValidator 控件用于使输入控件成为一个必需(必填)的字段。
      2. 属性:
        属性 描述
        InitialValue 定输入控件的初始值(开始值)。默认是 ""。
      3. 实例:

        用户名 (非空)

          4.代码:

      用户名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
                <asp:RequiredFieldValidator ID="RequiredFieldValidator1" InitialValue="" ControlToValidate="TextBox1"  runat="server" ErrorMessage="用户名不能为空"></asp:RequiredFieldValidator>

    6.ValidationSummary

       1.ValidationSummary 控件用于显示网页中所有验证错误的摘要。 

    2.主要 属性:

    属性 描述
    DisplayMode 如何显示摘要。合法值有:
    • BulletList
    • List
    • SingleParagraph
    HeaderText ValidationSummary 控件中的标题文本
    ShowMessageBox 布尔值,规定是否在消息框中显示验证摘要。
    ShowSummary 布尔值,规定 ValidationSummary 控件是否显示或者隐藏。

     

     

    7.注明:每个控件相同的属性有

    属性 描述
    id 控件的唯一 id。
    runat 规定该控件是一个服务器控件。必须设置为 "server"。
    ControlToValidate 要验证的控件的 id。
    ErrorMessage 当验证失败时,在 ValidationSummary 控件中显示的文本。 注释:如果未设置 Text 属性,文本也会显示在验证控件中。
    IsValid 布尔值,指示由 ControlToValidate 指定的控件是否通过验证。
    BackColor 控件的背景颜色。

     

     

     

  • 相关阅读:
    supermall遇到的问题
    github建立仓库
    【Teradata】9794 ERRAMPOUTOFPHYSPACE error解决方法
    MPP大规模并行计算数据库与分布式数据库的区别
    【English】20190515
    商业数据分析的四个层次
    学会学习(Learning how to learn)
    【English】20190513
    【Teradata】DEL语句产生的锁
    【Teradata】开启LockLogger与dumplocklog工具使用(含lokdisp工具说明)
  • 原文地址:https://www.cnblogs.com/yitou13/p/10108652.html
Copyright © 2011-2022 走看看