在flex实现数据验证(1)

 

数据验证是表单永远的话题,可能大家想也没想过,在flash中居然也会有验证控件,简单的如同asp.ner的验证控件.下面我们一起来体验一下.

      as3.0验证的类包为mx.Validators.包中有一个基类Validator,其他的类都为其子类

1.绑定验证对象

1.Validator有两个主要属性
[color=Red]source[/color]:表示验证的对象(比如验证一个文本框,它的ID为phoneInput,则soure属性应绑定这个对象.
source="{phoneInput}"
[color=Red]property[/color]:表示验证对象的属性(一个对象有很多属性,但你未指定验证哪一项,TextInput有一个text属性,就是我们的输入文本.所以表示验证的数据为text)

[img]http://www.clingingboy.com/blog/uploads/200607/03_222231_snap1.jpg[/img]

可能大家还是喜欢看效果,下面来看一个简单的例子,还是拿帮助文件的例子来讲

PhoneNumberValidator为一个验证电话号码的控件

代码一


 
 
xml version="1.0"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"> <mx:PhoneNumberValidator id="pnV" source="{phoneInput}" property="text"/> <mx:TextInput id="phoneInput"/> <mx:TextInput id="zipCodeInput"/> mx:Application>

 

下面试一下效果吧

先把鼠标放在第一个文本框上,然后鼠标移出,会发现文本眶颜色变为红色,表明验证未通过.再次将鼠标移到文本眶上如果文本没有输入任何文字的话,会出现默认提示(this field is required),表明此项为必填,如果验证结果与输入不符合的话会出现默认错误提示(your telephone number must contain at least 10 dights)
[flash]http://www.clingingboy.com/blog/uploads/200607/03_223220_text5.swf[/flash]

如果你不喜欢使用标签的话,你也可以以编程的方式来实现以上效果,当然如果简单验证的话,用标签就够了.以下使用编程实现验证

示例二


 
 
xml version="1.0"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"> <mx:Script> [CDATA[ // Import PhoneNumberValidator. import mx.validators.PhoneNumberValidator; // Create the validator. private var v:PhoneNumberValidator = new PhoneNumberValidator(); private function createValidator():void { // Configure the validator. v.source = phoneInput; v.property = "text"; } ]]> mx:Script> <mx:TextInput id="phoneInput" creationComplete="createValidator();"/> <mx:TextInput id="zipCodeInput"/> mx:Application>

 

2.使用按钮触发验证

第一个例子虽然实现了验证,但感觉验证的功能是可有可无的,当我们把鼠标移到文本眶上再移出才出发验证.如果我们预先不把鼠标移到文本眶上,这个验证就算无效了.我们可以利用按钮检查验证是否通过.如果验证未通过则文本眶显红色.

Validator还有两个属性

trigger:表示触发验证事件的对象
triggerEvent:表示对象触发验证事件的时机(如click,mouseOver等)

了解以上两个属性的话就可以解决第一个例子的问题了.看以下代码


 
 
xml version="1.0"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"> <mx:PhoneNumberValidator id="pnV" source="{phoneInput}" property="text" trigger="{btn}" triggerEvent="click" /> <mx:TextInput id="phoneInput"/> <mx:Button label="Button" id="btn"/> mx:Application>


试一下效果吧,现在你可以不用先把鼠标移动到文本眶上,直接点击按钮,你将发现文本眶显红色.现在你该明白了吧.

[flash]http://www.clingingboy.com/blog/uploads/200607/03_225428_text5.swf[/flash]

[b]3.修改默认提示错误[/b]

验证控件在默认情况下已经给出默认的提示错误,我们看E文肯定不爽,可否修改默认提示?当然可以.

Validator基类有一个requiredFieldError属性 表示必填项没填入数据的时的提示错误信息

然后呢每个验证控件都有自己不同的验证机制,属性也不相同,如PhoneNumberValidator有一个属性
wrongLengthError:表示输入的数据阿拉伯数字长度小于10时提示的错误信息
invalidCharError:表示输入数据不是阿拉伯数字时提示的错误信息
了解上面两个属性后,再看看效果


 
 
xml version="1.0"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"> <mx:PhoneNumberValidator id="pnV" source="{phoneInput}" property="text" trigger="{btn}" triggerEvent="click" requiredFieldError="此项为必填" invalidCharError="请输入阿拉伯数字" wrongLengthError="请至少输入请输入10个阿拉伯数字" /> <mx:TextInput id="phoneInput"/> <mx:Button label="Button" id="btn"/> mx:Application>

[flash]http://www.clingingboy.com/blog/uploads/200607/03_232442_text5.swf[/flash]

好了,最简单的讲完了.介绍了三个功能,其实也就学习几个属性而已,不知道大家感不感兴趣,当然还有其他验证,并没这么简单,有时间再跟大家分享.上面讲的三点你学会了吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值