C#验证控件的使用方法
C#验证控件的使用方法 |
[ 2007-12-1 15:36:00 | By: maje ]
|
C#验证控件的使用方法 2、CompareValidator:比较验证。比较两个字段值是否相等,如密码和确认密码两个字段是否相等;比较一个字段与一个具体的值。 3、RangeValidator:范围验证。验证一个字段是否在某个范围中,如成绩字段要是0~100范围中。 4、RegularExpressionValidator:正则表达式验证。它根据正则表达式来验证用户输入字段的格式是否合法,如电子邮件、身份证、电话号码等。 5、CustomValidator:在运行定制的客户端JavaScript或VBScript函数时,可以使用这个控件。 那么,如何使用验证控件呢? 1、使用Visual Studio .NET 2003 命令提示工具运行aspnet_regiis -c命令复制ASP.NET客户端脚本文件。
2、把验证控件放在要验证的控件右边。如图
3、修改验证控件的ControlToValidate属性为要验证的控件名。 4、把验证控件的ErrorMessage属性修改更具体的错误描述信息,如“请输入正确的电子邮件密码”、“密码不一致”、“必填字段”等。 5、如果是使用RequiredFieldValidator必填验证控件,到这步就OK了。但是,如果使用的是其它几个控件,还需要作以下设置: A、CompareValidator控件,比较两个控件的值,要设置ControlToCompare、Operator和Type属性。如果是要比较一个控件和一个具体的值,需要修改ValueToCompare、Operator和Type属性。 B、RangeValidator控件,分别在MinimunValue和MaximumValue属性中设置最小值和最大值,还需要把Type属性改为Currency或Integer。 C、RegularExpress控件:通过ValidationExpress属性,从列表中选择一个新的正则表达式。 最后,需要注意的是,每一个字段都可以使用多个不周类型的验证控件进行验证。
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中的 六、CustomValidator(自定义验证)控件 该控件用自定义的函数界定验证方式,其标准代码如下: <ASP:CustomValidator id="Validator_ID" RunAt="Server" controlToValidate="要验证的控件" onServerValidateFunction="验证函数" errorMessage="错误信息" Display="Static|Dymatic|None" > 占位符 </ASP: CustomValidator > 以上代码中,用户必须定义一个函数来验证输入。
2 验证控件的使用: (1)忘记聚焦 SetFocusOnError 属性设为true。
(2) 当我们运用文本框输入很多数据的时候,需要把图textBox的属性Textmode的属性改为multiLine多行,这时候的maxlength的属性就不能起作用了,我们做验证的时候就需要用验证控件regularexpressionValidator,其中正则表达式[‘<>’]{0,n} 其中n是设置的最大值。 七、总结 ASP.NET验证控件已经介绍完了,大家可以发现它们的功能很强大,再也不要为验证而烦恼了。当然,以上介绍并不是特别详细,细微的地方,还请大家自己阅读微软的SDK。 |