• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Asp.Net验证控件浅析

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

ASP.NET公有六种验证控件,分别如下:

控件名           功能描叙 
RequiredFieldValidator(必须字段验证) 用于检查是否有输入值 
CompareValidator(比较验证) 按设定比较两个输入 
RangeValidator(范围验证) 输入是否在指定范围 
RegularExpressionValidator(正则表达式验证) 正则表达式验证控件 
CustomValidator(自定义验证) 自定义验证控件 
ValidationSummary(验证总结) 总结验证结果

下面,我们来看这些控件的使用:

一、RequiredFieldValidator(必须字段验证)的使用

RequiredFieldValidator控件使用的标准代码如下:

 

 
  1. <ASP:RequiredFieldValidator id="Validator_Name" Runat="Server"  
  2.    ControlToValidate="要检查的控件名"  
  3.    ErrorMessage="出错信息"  
  4.    Display="Static|Dymatic|None"  
  5.  >  
  6.  占位符  
  7. </ASP: RequiredFieldValidator >  



 

在以上标准代码中:
  ControlToValidate:表示要进行检查控件ID;
  ErrorMessage:表示当检查不合法时,出现的错误信息;
  Display:错误信息的显示方式;Static表示控件的错误信息在页面中占有肯定位置;Dymatic表示控件错误信息出现时才占用页面控件;None表示错误出现时不显示,但是可以在ValidatorSummary中显示;
  占位符:表示Display为Static时,错误信息占有"占位符"那么大的页面空间;

现在,让我们看一个实例:


  1. <ASP:TextBox id="txtName" RunAt="Server"/>  
  2. <ASP:RequiredFieldValidator id="Validator1" Runat="Server"  
  3.    ControlToValidate="txtName"  
  4.    ErrorMessage="姓名必须输入"  
  5.    Display="Static">  
  6.   *姓名必须输入  
  7. </ASP:RequiredFieldValidator>  



 

在以上例子中,检查txtName控件是否有输入,如果没有,显示错误信息"姓名必须输入"。是不是很简单?
注意:以上代码和下面其他控件的代码最好放入Form中,和ASP中不一样的是,Form最好写为这样:
<Form RunAt="Server">
其他代码
</Form>  
这样,Form在服务器端执行,提交才会有效;

二、CompareValidator(比较验证)控件

比较控件比较两个控件的输入是否符合程序设定,大家不要把比较仅仅理解为"相等",尽管相等是用的最多的,其实,这里的比较包括范围很广,大家看标准代码就会明白。

比较控件的标准代码如下:


  1. <ASP:CompareValidator id="Validator_ID" RunAt="Server"  
  2. ControlToValidate="要验证的控件ID"  
  3. errorMessage="错误信息"  
  4. ControlToCompare="要比较的控件ID"  
  5. type="String|Integer|Double|DateTime|Currency"  
  6. operator="Equal|NotEqual|GreaterThan|GreaterTanEqual|LessThan|LessThanEqual|DataTypeCheck"  
  7. Display="Static|Dymatic|None"  
  8. >  
  9. 占位符  
  10. </ASP:CompareValidator>  



 

在以上标准代码中:
  Type表示要比较的控件的数据类型;
  Operator表示比较操作(也就是刚才说的为什么比较不仅仅是"相等"的原因),这里,比较有7种方式;
  其他属性和RequiredFieldValidator相同;
  在这里,要注意ControlToValidate和ControlToCompare的区别,如果operate为GreateThan,那么,必须ControlToCompare大于ControlToValidate才是合法的,这下,应该明白它们两者的意义了吧?例子程序请参考RequiredFieldValidator控件,对照标准代码自己设计。

三、RangeValidator(范围验证)控件

验证输入是否在一定范围,范围用MaximumValue(最大)和MinimunVlaue来确定,标准代码如下:

 

 
  1. <ASP:RangeValidator id="Vaidator_ID" Runat="Server"   
  2. controlToValidate="要验证的控件ID"  
  3. type="Integer"  
  4. MinimumValue="最小值"  
  5. MaximumValue="最大值"  
  6. errorMessage="错误信息"  
  7. Display="Static|Dymatic|None"  
  8. >  
  9. 占位符  
  10. </ASP:RangeValidator>  



 

在以上代码中:
用MinimumValue和MaximumValue来界定控件输入值得范围,用type来定义控件输入值的类型。

四、RegularExpresionValidator(正则表达式)控件

正则表达式验证控件的功能非常强大,你可以自己容易构造验证方式,我们先来看看标准代码:

 

 
  1. <ASP:RegularExpressionValidator id="Validator_ID" RunAt="Server"  
  2. ControlToValidate="要验证控件名"  
  3. ValidationExpression="正则表达式"  
  4. errorMessage="错误信息"  
  5. display="Static"  
  6. >  
  7. 占位符  
  8. </ASP:RegularExpressionValidator>  

 

在以上标准代码中,ValidationExpression是重点,现在来看看它的构造:
  在ValidationExpression中,不同的字符表示不同的含义:
  "."表示任意字符;
  "*"表示和其他表达式一起,表示容易组合;
  "[A-Z]"表示任意大写字母;
  "\d"表示容易一个数字;
  注意,在以上表达式中,引号不包括在内;
  举例:
   正则表达式:".*[A-Z]"表示数字开头的任意字符组合其后接一个大写字母。

五、ValidationSummary(验证总结)控件

该控件收集本页的所有验证错误信息,并可以将它们组织以后再显示出来。其标准代码如下:

 

 
  1. <ASP:ValidationSummary id="Validator_ID" RunAT="Server"  
  2. HeaderText="头信息"  
  3. ShowSummary="True|False"  
  4. DiaplayMode="List|BulletList|SingleParagraph"  
  5. >  
  6. </ASP: ValidationSummary >    



在以上标准代码中,HeadText相当于表的HeadText,DisplayMode表示错误信息显示方式:List相当于HTML中的<BR>;BulletList相当于HTML中的<LI>;SingleParegraph表示错误信息之间不作如何分割;

 

六、CustomValidator(自定义验证)控件

该控件用自定义的函数界定验证方式,其标准代码如下:

 

 
  1. <ASP:CustomValidator id="Validator_ID" RunAt="Server"  
  2. controlToValidate="要验证的控件"  
  3. onServerValidateFunction="验证函数"  
  4. errorMessage="错误信息"  
  5. Display="Static|Dymatic|None"  
  6. >  
  7. 占位符  
  8. </ASP: CustomValidator >  



 

以上代码中,用户必须定义一个函数来验证输入。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap