【ASP.NET】Validation 服务器控件
Validation 服务器控件
Validation 服务器控件用于验证输入控件的数据。如果数据未通过验证,则向用户显示错误消息。
创建 Validation 服务器控件的语法是:
<asp:control_name id="some_id" runat="server" />
Validation 服务器控件 | 描述 |
---|---|
CompareValidator | 把一个输入控件的值与另一个输入控件或一个固定的值进行对比。 |
CustomValidator | 允许您编写一个方法,来处理输入值的验证。 |
RangeValidator | 在两个值的范围内检查输入的值。 |
RegularExpressionValidator | 确保输入控件的值匹配指定的模式。 |
RequiredFieldValidator | 是输入控件成为必需(必填)的字段。 |
ValidationSummary | 显示网页中所有验证错误的报告。 |
- CompareValidator
- CompareValidator 控件用于将一个输入控件的值与另一个输入控件的值或常数值进行比较。
- 主要属性:
描述 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
- 实例:
添加一个名为CompareValidator.aspx的Web页面,在其中添加一个文本框,用于输入日期,要求输入的日期必须是一个当前日期以后的日期,使用CompareValidator控件来验证文本框的输入。
- 代码:
<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>
-
- CustomValidator 控件允许您书写处理输入值验证的方法。
- 属性:
属性 描述 ClientValidationFunction 规定要被执行的客户端脚本函数的名称。 OnServerValidate 规定被执行的服务器端验证脚本函数的名称。 - 实例:
添加一个名为CustomValidator.aspx的Web页面,编写自定义验证控件的验证代码用于验证输入的正整数是素数。
- 代码:
<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; }
- RangeValidator
- RangeValidator 控件用于检测用户输入的值是否介于两个值之间。可以对不同类型的值进行比较,比如数字、日期和字符。
- 属性:
属性 描述 MaximumValue 规定输入控件的最大值。 MinimumValue 规定输入控件的最小值。 - 实例:
添加一个名为RangeValidator.aspx的Web页面,在其中添加一个“考生年龄”的输入文本框,要求输入的值必须在18到80之间,使用RangeValidator控件验证用户在文本框中输入的内容是否在有效范围内。
- 代码:
<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>
- RegularExpressionValidator
- RegularExpressionValidator 控件用于验证输入值是否匹配指定的模式。
- 主要属性:
属性 描述 ValidationExpression 规定验证输入控件的正则表达式。 - 实例:验证
固定电话 (区号-电话号)
Email( someone@domain.com)1129875586@qq.com
- 代码:
电子邮箱:<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>
- RequiredFieldValidator
- RequiredFieldValidator 控件用于使输入控件成为一个必需(必填)的字段。
- 属性:
属性 描述 InitialValue 定输入控件的初始值(开始值)。默认是 ""。 - 实例:
用户名 (非空)
4.代码:
用户名:<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox> <asp:RequiredFieldValidator ID="RequiredFieldValidator1" InitialValue="" ControlToValidate="TextBox1" runat="server" ErrorMessage="用户名不能为空"></asp:RequiredFieldValidator>
1.ValidationSummary 控件用于显示网页中所有验证错误的摘要。
2.主要 属性:
属性 | 描述 |
DisplayMode | 如何显示摘要。合法值有:
|
HeaderText | ValidationSummary 控件中的标题文本 |
ShowMessageBox | 布尔值,规定是否在消息框中显示验证摘要。 |
ShowSummary | 布尔值,规定 ValidationSummary 控件是否显示或者隐藏。 |
7.注明:每个控件相同的属性有
属性 | 描述 |
id | 控件的唯一 id。 |
runat | 规定该控件是一个服务器控件。必须设置为 "server"。 |
ControlToValidate | 要验证的控件的 id。 |
ErrorMessage | 当验证失败时,在 ValidationSummary 控件中显示的文本。 注释:如果未设置 Text 属性,文本也会显示在验证控件中。 |
IsValid | 布尔值,指示由 ControlToValidate 指定的控件是否通过验证。 |
BackColor | 控件的背景颜色。 |