在做项目是我遇到了验证控件,但我不是很了解。所以我从网上搜集了一些资料。
第一篇
ASP.NET公有六种验证控件,分别如下:
控件名 功能描叙
RequiredFieldValidator(必须字段验证) 用于检查是否有输入值
CompareValidator(比较验证) 按设定比较两个输入
RangeValidator(范围验证) 输入是否在指定范围
RegularExpressionValidator(正则表达式验证) 正则表达式验证控件
CustomValidator(自定义验证) 自定义验证控件
ValidationSummary(验证总结) 总结验证结果
RequiredFieldValidator(必须字段验证) 用于检查是否有输入值
CompareValidator(比较验证) 按设定比较两个输入
RangeValidator(范围验证) 输入是否在指定范围
RegularExpressionValidator(正则表达式验证) 正则表达式验证控件
CustomValidator(自定义验证) 自定义验证控件
ValidationSummary(验证总结) 总结验证结果
下面,我们来看这些控件的使用
一:RequiredFieldValidator(必须字段验证)的使用
RequiredFieldValidator控件使用的标准代码如下:
<ASP:RequiredFieldValidator id="Validator_Name" Runat="Server"
ControlToValidate="要检查的控件名"
ErrorMessage="出错信息"
Display="Static|Dymatic|None"
>
占位符
</ASP: RequiredFieldValidator >
一:RequiredFieldValidator(必须字段验证)的使用
RequiredFieldValidator控件使用的标准代码如下:
<ASP:RequiredFieldValidator id="Validator_Name" Runat="Server"
ControlToValidate="要检查的控件名"
ErrorMessage="出错信息"
Display="Static|Dymatic|None"
>
占位符
</ASP: RequiredFieldValidator >
在以上标准代码中:
ControlToValidate:表示要进行检查控件ID;
ErrorMessage:表示当检查不合法时,出现的错误信息;
Display:错误信息的显示方式;Static表示控件的错误信息在页面中占有肯定位置;Dymatic表示控件错误信息出现时才占用页面控件;None表示错误出现时不显示,但是可以在ValidatorSummary中显示;
占位符:表示Display为Static时,错误信息占有"占位符"那么大的页面空间;
ControlToValidate:表示要进行检查控件ID;
ErrorMessage:表示当检查不合法时,出现的错误信息;
Display:错误信息的显示方式;Static表示控件的错误信息在页面中占有肯定位置;Dymatic表示控件错误信息出现时才占用页面控件;None表示错误出现时不显示,但是可以在ValidatorSummary中显示;
占位符:表示Display为Static时,错误信息占有"占位符"那么大的页面空间;
现在,让我们看一个实例:
<ASP:TextBox id="txtName" RunAt="Server"/>
<ASP:RequiredFieldValidator id="Validator1" Runat="Server"
ControlToValidate="txtName"
ErrorMessage="姓名必须输入"
Display="Static">
*姓名必须输入
</ASP:RequiredFieldValidator>
<ASP:TextBox id="txtName" RunAt="Server"/>
<ASP:RequiredFieldValidator id="Validator1" Runat="Server"
ControlToValidate="txtName"
ErrorMessage="姓名必须输入"
Display="Static">
*姓名必须输入
</ASP:RequiredFieldValidator>
在以上例子中,检查txtName控件是否有输入,如果没有,显示错误信息"姓名必须输入"。是不是很简单?
注意:以上代码和下面其他控件的代码最好放入Form中,和ASP中不一样的是,Form最好写为这样:
<Form RunAt="Server">
其他代码
</Form>
这样,Form在服务器端执行,提交才会有效;
注意:以上代码和下面其他控件的代码最好放入Form中,和ASP中不一样的是,Form最好写为这样:
<Form RunAt="Server">
其他代码
</Form>
这样,Form在服务器端执行,提交才会有效;
二:CompareValidator(比较验证)控件
比较控件比较两个控件的输入是否符合程序设定,大家不要把比较仅仅理解为"相等",尽管相等是用的最多的,其实,这里的比较包括范围很广,大家看标准代码就会明白。
比较控件的标准代码如下:
<ASP:CompareValidator id="Validator_ID" RunAt="Server"
ControlToValidate="要验证的控件ID"
errorMessage="错误信息"
ControlToCompare="要比较的控件ID"
type="String|Integer|Double|DateTime|Currency"
operator="Equal|NotEqual|GreaterThan|GreaterTanEqual|LessThan|LessThanEqual|DataTypeCheck"
Display="Static|Dymatic|None"
>
占位符
</ASP:CompareValidator>
比较控件比较两个控件的输入是否符合程序设定,大家不要把比较仅仅理解为"相等",尽管相等是用的最多的,其实,这里的比较包括范围很广,大家看标准代码就会明白。
比较控件的标准代码如下:
<ASP:CompareValidator id="Validator_ID" RunAt="Server"
ControlToValidate="要验证的控件ID"
errorMessage="错误信息"
ControlToCompare="要比较的控件ID"
type="String|Integer|Double|DateTime|Currency"
operator="Equal|NotEqual|GreaterThan|GreaterTanEqual|LessThan|LessThanEqual|DataTypeCheck"
Display="Static|Dymatic|None"
>
占位符
</ASP:CompareValidator>
在以上标准代码中:
Type表示要比较的控件的数据类型;
Operator表示比较操作(也就是刚才说的为什么比较不仅仅是"相等"的原因),这里,比较有7种方式;
其他属性和RequiredFieldValidator相同;
在这里,要注意ControlToValidate和ControlToCompare的区别,如果operate为GreateThan,那么,必须ControlToCompare大于ControlToValidate才是合法的。
Type表示要比较的控件的数据类型;
Operator表示比较操作(也就是刚才说的为什么比较不仅仅是"相等"的原因),这里,比较有7种方式;
其他属性和RequiredFieldValidator相同;
在这里,要注意ControlToValidate和ControlToCompare的区别,如果operate为GreateThan,那么,必须ControlToCompare大于ControlToValidate才是合法的。
ValidationCompareOperator 枚举
成员名称 | 说明 | |
---|---|---|
DataTypeCheck | 只对数据类型进行的比较。? | |
Equal | 相等比较。? | |
GreaterThan | 大于比较。? | |
GreaterThanEqual | 大于或等于比较。? | |
LessThan | 小于比较。? | |
LessThanEqual | 小于或等于比较。? | |
NotEqual | 不等于比较。? |
例:比较验证
private void lstOperator_SelectedIndexChanged(object sender, System.EventArgs e) //事件
{
comp1.Operator = (ValidationCompareOperator) lstOperator.SelectedIndex; //取得验证控件Operator的值
comp1.Validate(); //对关联的输入控件执行验证或更新
}
{
comp1.Operator = (ValidationCompareOperator) lstOperator.SelectedIndex; //取得验证控件Operator的值
comp1.Validate(); //对关联的输入控件执行验证或更新
}
三:RangeValidator(范围验证)控件
验证输入是否在一定范围,范围用MaximumValue(最大)和MinimunVlaue来确定,标准代码如下:
<ASP:RangeValidator id="Vaidator_ID" Runat="Server"
controlToValidate="要验证的控件ID"
type="Integer"
MinimumValue="最小值" //属性
MaximumValue="最大值"
errorMessage="错误信息"
Display="Static|Dymatic|None"
>
占位符
</ASP:RangeValidator>
在以上代码中:
用MinimumValue和MaximumValue来界定控件输入值得范围,用type来定义控件输入值的类型。
验证输入是否在一定范围,范围用MaximumValue(最大)和MinimunVlaue来确定,标准代码如下:
<ASP:RangeValidator id="Vaidator_ID" Runat="Server"
controlToValidate="要验证的控件ID"
type="Integer"
MinimumValue="最小值" //属性
MaximumValue="最大值"
errorMessage="错误信息"
Display="Static|Dymatic|None"
>
占位符
</ASP:RangeValidator>
在以上代码中:
用MinimumValue和MaximumValue来界定控件输入值得范围,用type来定义控件输入值的类型。
例:数值型范围验证
rangeValInteger.Validate();
if (rangeValInteger.IsValid)
{
lblOutput1.Text = "结果:有效!";
}
else
{
lblOutput1.Text = "结果:无效!";
}
日期型范围验证
if (rangeValInteger.IsValid)
{
lblOutput1.Text = "结果:有效!";
}
else
{
lblOutput1.Text = "结果:无效!";
}
日期型范围验证
rangeValDate.Validate();
if (rangeValDate.IsValid)
{
lblOutput2.Text = "结果:有效!";
}
else
{
lblOutput2.Text = "结果:无效!";
}
if (rangeValDate.IsValid)
{
lblOutput2.Text = "结果:有效!";
}
else
{
lblOutput2.Text = "结果:无效!";
}
字符串范围验证
rangeValString.Validate();
if (rangeValString.IsValid)
{
lblOutput3.Text = "结果:有效!";
}
else
{
lblOutput3.Text = "结果:无效!";
}
四:RegularExpresionValidator(正则表达式)控件
正则表达式验证控件的功能非常强大,你可以自己容易构造验证方式,我们先来看看标准代码:
<ASP:RegularExpressionValidator id="Validator_ID" RunAt="Server"
ControlToValidate="要验证控件名"
ValidationExpression="正则表达式"
errorMessage="错误信息"
display="Static"
>
占位符
</ASP:RegularExpressionValidator>
在以上标准代码中,ValidationExpression是重点,现在来看看它的构造:
在ValidationExpression中,不同的字符表示不同的含义:
"."表示任意字符;
"*"表示和其他表达式一起,表示容易组合;
"[A-Z]"表示任意大写字母;
"\d"表示容易一个数字;
注意,在以上表达式中,引号不包括在内;
举例:
正则表达式:".*[A-Z]"表示数字开头的任意字符组合其后接一个大写字母。
五:ValidationSummary(验证总结)控件
该控件收集本页的所有验证错误信息,并可以将它们组织以后再显示出来。其标准代码如下:
<ASP:ValidationSummary id="Validator_ID" RunAT="Server"
HeaderText="头信息"
ShowSummary="True|False"
DiaplayMode="List|BulletList|SingleParagraph"
>
</ASP: ValidationSummary >
在以上标准代码中,HeadText相当于表的HeadText,DisplayMode表示错误信息显示方式:List相当于HTML中的<BR>;BulletList相当于HTML中的<LI>;SingleParegraph表示错误信息之间不作如何分割;
if (rangeValString.IsValid)
{
lblOutput3.Text = "结果:有效!";
}
else
{
lblOutput3.Text = "结果:无效!";
}
四:RegularExpresionValidator(正则表达式)控件
正则表达式验证控件的功能非常强大,你可以自己容易构造验证方式,我们先来看看标准代码:
<ASP:RegularExpressionValidator id="Validator_ID" RunAt="Server"
ControlToValidate="要验证控件名"
ValidationExpression="正则表达式"
errorMessage="错误信息"
display="Static"
>
占位符
</ASP:RegularExpressionValidator>
在以上标准代码中,ValidationExpression是重点,现在来看看它的构造:
在ValidationExpression中,不同的字符表示不同的含义:
"."表示任意字符;
"*"表示和其他表达式一起,表示容易组合;
"[A-Z]"表示任意大写字母;
"\d"表示容易一个数字;
注意,在以上表达式中,引号不包括在内;
举例:
正则表达式:".*[A-Z]"表示数字开头的任意字符组合其后接一个大写字母。
五:ValidationSummary(验证总结)控件
该控件收集本页的所有验证错误信息,并可以将它们组织以后再显示出来。其标准代码如下:
<ASP:ValidationSummary id="Validator_ID" RunAT="Server"
HeaderText="头信息"
ShowSummary="True|False"
DiaplayMode="List|BulletList|SingleParagraph"
>
</ASP: ValidationSummary >
在以上标准代码中,HeadText相当于表的HeadText,DisplayMode表示错误信息显示方式:List相当于HTML中的<BR>;BulletList相当于HTML中的<LI>;SingleParegraph表示错误信息之间不作如何分割;
例:
private void ListFormat_SelectedIndexChanged(object sender, System.EventArgs e)
{
valSum.DisplayMode = (ValidationSummaryDisplayMode) ListFormat.SelectedIndex; //当listformat控件更改项时,控件的DidplsyMode属性随时随着改变
}
{
valSum.DisplayMode = (ValidationSummaryDisplayMode) ListFormat.SelectedIndex; //当listformat控件更改项时,控件的DidplsyMode属性随时随着改变
}
BulletList | (默认)每个消息都显示为单独的项。 |
List | 每个消息显示在单独的行中。 |
SingleParagraph | 每个消息显示为段落中的一个句子。 |
六:CustomValidator(自定义验证)控件
该控件用自定义的函数界定验证方式,其标准代码如下:
<ASP:CustomValidator id="Validator_ID" RunAt="Server"
controlToValidate="要验证的控件"
onServerValidateFunction="验证函数"
errorMessage="错误信息"
Display="Static|Dymatic|None"
>
占位符
</ASP: CustomValidator >
以上代码中,用户必须定义一个函数来验证输入。
private void CustomValidator1_ServerValidate(object source, System.Web.UI.WebControls.ServerValidateEventArgs args) //自定义验证 --- 奇偶数
{
try
{
int num = Int32.Parse(args.Value);
if (num%2 == 0)
{
args.IsValid = true;
return; //如果是偶数就返回了,不会执行以下代码
}
}
catch (Exception) {} //表示执行中发生的错误
args.IsValid = false;
}
{
try
{
int num = Int32.Parse(args.Value);
if (num%2 == 0)
{
args.IsValid = true;
return; //如果是偶数就返回了,不会执行以下代码
}
}
catch (Exception) {} //表示执行中发生的错误
args.IsValid = false;
}
第二篇
ASP.NET验证控件
用来验证表单的验证器(Web控件)
ASP.NET是微软推出的下一代WEB开发工具,我们来看看ASP.NET的验证控件,感受ASP.NET的强大功能。有了ASP.NET,你不但可以轻松的实现对用户输入的验证,而且,还可以选择验证在服务器端进行还是在客户端进行,再也不必考虑那么多了,程序员们可以将重要精力放在主程序的设计上了。
ASP.NET公有六种验证控件,分别如下:
控件名及功能描叙
用于检查是否有输入值 : RequiredFieldValidator(必须字段验证) 按设定比较两个输入 :CompareValidator(比较验证) 输入是否在指定范围 :RangeValidator(范围验证) 正则表达式验证控件 :RegularExpressionValidator(正则表达式验证) 自定义验证控件 :CustomValidator(自定义验证) 总结验证结果 :ValidationSummary(验证总结)
下面,我们来看这些控件的使用
一:RequiredFieldValidator(必须字段验证)的使用 RequiredFieldValidator控件使用的标准代码如下: <ASP:RequiredFieldValidator id="Validator_Name" Runat="Server" ControlToValidate="要检查的控件名" ErrorMessage="出错信息" Display="Static|Dymatic|None">占位符</ASP: RequiredFieldValidator > 在以上标准代码中: ControlToValidate:表示要进行检查控件ID; ErrorMessage:表示当检查不合法时,出现的错误信息; Display:错误信息的显示方式;Static表示控件的错误信息在页面中占有肯定位置;Dymatic表示控件错误信息出现时才占用页面控件;None表示错误出现时不显示,但是可以在ValidatorSummary中显示; 占位符:表示Display为Static时,错误信息占有"占位符"那么大的页面空间; 现在,让我们看一个实例: <ASP:TextBox id="txtName" RunAt="Server"/> <ASP:RequiredFieldValidator id="Validator1" Runat="Server" ControlToValidate="txtName" ErrorMessage="姓名必须输入" Display="Static">*姓名必须输入</ASP:RequiredFieldValidator> 在以上例子中,检查txtName控件是否有输入,如果没有,显示错误信息"姓名必须输入"。是不是很简单? 注意:以上代码和下面其他控件的代码最好放入Form中,和ASP中不一样的是,Form最好写为这样: <Form RunAt="Server">其他代码</Form> 这样,Form在服务器端执行,提交才会有效; 二:CompareValidator(比较验证)控件 比较控件比较两个控件的输入是否符合程序设定,大家不要把比较仅仅理解为"相等",尽管相等是用的最多的,其实,这里的比较包括范围很广,大家看标准代码就会明白。 比较控件的标准代码如下: <ASP:CompareValidator id="Validator_ID" RunAt="Server" ControlToValidate="要验证的控件ID" errorMessage="错误信息" ControlToCompare="要比较的控件ID" type="String|Integer|Double|DateTime|Currency" operator="Equal|NotEqual|GreaterThan|GreaterTanEqual|LessThan|LessThanEqual|DataTypeCheck" Display="Static|Dymatic|None">占位符</ASP:CompareValidator> 在以上标准代码中: Type表示要比较的控件的数据类型; Operator表示比较操作(也就是刚才说的为什么比较不仅仅是"相等"的原因),这里,比较有7种方式; 其他属性和RequiredFieldValidator相同; 在这里,要注意ControlToValidate和ControlToCompare的区别,如果operate为GreateThan,那么,必须ControlToCompare大于ControlToValidate才是合法的,这下,应该明白它们两者的意义了吧?例子程序请参考RequiredFieldValidator控件,对照标准代码自己设计。 三:RangeValidator(范围验证)控件 验证输入是否在一定范围,范围用MaximumValue(最大)和MinimunVlaue来确定,标准代码如下: <ASP:RangeValidator id="Vaidator_ID" Runat="Server" controlToValidate="要验证的控件ID" type="Integer" MinimumValue="最小值" MaximumValue="最大值" errorMessage="错误信息" Display="Static|Dymatic|None">占位符</ASP:RangeValidator> 在以上代码中: 用MinimumValue和MaximumValue来界定控件输入值得范围,用type来定义控件输入值的类型。 四:RegularExpresionValidator(正则表达式)控件 正则表达式验证控件的功能非常强大,你可以自己容易构造验证方式,我们先来看看标准代码: <ASP:RegularExpressionValidator id="Validator_ID" RunAt="Server" ControlToValidate="要验证控件名" ValidationExpression="正则表达式" errorMessage="错误信息" display="Static">占位符</ASP:RegularExpressionValidator> 在以上标准代码中,ValidationExpression是重点,现在来看看它的构造: 在ValidationExpression中,不同的字符表示不同的含义: "."表示任意字符; "*"表示和其他表达式一起,表示容易组合; "[A-Z]"表示任意大写字母; "\d"表示容易一个数字; 注意,在以上表达式中,引号不包括在内; 举例: 正则表达式:".*[A-Z]"表示数字开头的任意字符组合其后接一个大写字母。 五:ValidationSummary(验证总结)控件 该控件收集本页的所有验证错误信息,并可以将它们组织以后再显示出来。其标准代码如下: <ASP:ValidationSummary id="Validator_ID" RunAT="Server" HeaderText="头信息" ShowSummary="True|False" DiaplayMode="List|BulletList|SingleParagraph"></ASP: ValidationSummary > 在以上标准代码中,HeadText相当于表的HeadText,DisplayMode表示错误信息显示方式: List相当于HTML中的<BR>; BulletList相当于HTML中的<LI>; SingleParegraph表示错误信息之间不作如何分割; 六:CustomValidator(自定义验证)控件 该控件用自定义的函数界定验证方式,其标准代码如下: <ASP:CustomValidator id="Validator_ID" RunAt="Server" controlToValidate="要验证的控件" onServerValidateFunction="验证函数" errorMessage="错误信息" Display="Static|Dymatic|None">占位符</ASP: CustomValidator > 以上代码中,用户必须定义一个函数来验证输入。 |
转载于:https://blog.51cto.com/simeixiaofeng/167720