ASP.NET中验证控件的使用方法

网络编程 2021-07-04 22:41www.168986.cn编程入门
这篇文章主要内容是ASP.NET中验证控件的使用方法,RequiredFieldValidation控件的介绍,需要的朋友可以参考下

对于这些常用的控件有效性验证,在Asp.Net中有单独的验证控件可供使用。他们可以满足一般的,诸如非空,范围、比较等的验证,为用户登录页面添加输入数据验证功能和验证码功能。 

验证控件

   Asp.Net中内置的验证控件有RequiredFieldValidation、RangeValidation、RegularExpressValidation、CompareValidation、CustomValidation和ValidationSummary等六种。其中用户自定义验证控件,由于并不非常常用(要自定义很多成分,包括函数等),在此文不予论述。

   简单的验证界面如下(Design视图)

 

如图展示了选取环境,右边红色字体为验证控件的ErrorMessage信息。设计的环境布置如下

1)RequiredFieldValidation控件,其ControlToValidate属性为姓名对应文本框。对于ControlToValidate属性,每一个验证控件均对应一个,作为验证的主体;

2)RangeValidation控件, 其ControlToValidate属性为年龄对应文本框;

3)CompareValidation控件, 其ControlToValidate属性为密码确认对应文本框。还有一个容易和ControlToValidate属性相混淆的属性ControlToCompare属性,其对应密码对应文本框。区分的要点即是分清主体,此时验证的主体是密码确认对应框,在用operator时(等于、大于、小于),是比较的主体,和被比较的文本框相比较,这里即是密码对应文本框。

4)RegularExpressValidation控件, 其ControlToValidate属性为邮箱对应文本框;

5) ValidationSummary控件,它不具备ControlToValidate属性;

其对应的前台代码为

<head runat="server">
 <title>验证控件的演示页面</title>
 <script type ="text/javascript" >

 // Notes: 采用一张模拟用户表的例子验证

 </script>
</head>
<body>
 <form id="form1" runat="server">
 <div>
  姓名 <asp:TextBox ID="txtRequiredField" runat="server"></asp:TextBox>
  <asp:RequiredFieldValidator ID="RequiredFieldValidator1" runat="server" 
   ErrorMessage="姓名不能为空!" ControlToValidate="txtRequiredField"></asp:RequiredFieldValidator>
   <br/>
   年龄<asp:TextBox ID="txtRange" runat="server"></asp:TextBox>
  <asp:RangeValidator ID="RangeValidator1" runat="server" 
   ErrorMessage="年龄不在规定范围内!" ControlToValidate="txtRange" MaximumValue="100" 
   MinimumValue="0" Type="Integer"></asp:RangeValidator>
  <br />
  密码<asp:TextBox ID="txtPassword" runat="server"></asp:TextBox>
  <br />
  密码确认<asp:TextBox ID="txtPasswordConfirm" runat="server"></asp:TextBox>
  <asp:CompareValidator ID="CompareValidator1" runat="server" 
   ErrorMessage="密码前后输入,不一致!" ControlToCompare="txtPassword" 
   ControlToValidate="txtPasswordConfirm"></asp:CompareValidator>
   <br />
   邮箱<asp:TextBox ID="txtMail" runat="server"></asp:TextBox>
  <asp:RegularExpressionValidator ID="RegularExpressionValidator1" runat="server" 
   ErrorMessage="邮箱格式不符!" ControlToValidate="txtMail" 
   ValidationExpression="\w+([-+.']\w+)@\w+([-.]\w+)\.\w+([-.]\w+)"></asp:RegularExpressionValidator>
  <br />
  <asp:ValidationSummary ID="ValidationSummary1" runat="server" 
   HeaderText="验证信息汇总" />
   <br /> 
  <asp:Button ID="btnSubmit" runat="server" Text="提交" onclick="btnSubmit_Click" /> 
 </div>
 </form>
</body>
</html>

当文本框的输入不符时,出现界面为

 

        对于所有RequiredFieldValidation控件,当其只针对姓名框时,当其余框为空时,它们对应的验证控件均失效。 可以认为除RequiredFieldValidation控件,其余控件都要在此控件基础上才能起作用。

为大家附3个精彩的专题

 以上就是本文的全部内容,希望对大家使用ASP.NET中验证控件有所帮助。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by