1. A simple example for static bind validator
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600"> <fx:Declarations> <mx:StringValidator id="usernameValidator" source="{username}" property="text"/> <mx:NumberValidator id="ageValidator" domain="int" maxValue="150" minValue="0" source="{age}" property="text"/> <mx:DateValidator id="birthDayValidator" inputFormat="YYYY-MM-DD" source="{birthDay}" property="text"/> </fx:Declarations> <fx:Script> <![CDATA[ import mx.controls.Alert; import mx.events.ValidationResultEvent; import mx.validators.Validator; private var validateSucceed:Boolean = false; private function submit():void { var validationResult:Array = Validator.validateAll([usernameValidator, ageValidator, birthDayValidator]); if (validationResult.length != 0) { Alert.show("Validate error!"); } else { Alert.show("Validate succeed!"); } } ]]> </fx:Script> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Name"/> <mx:TextInput id="username"/> </mx:VBox> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Age"/> <mx:TextInput id="age" restrict="0-9" maxChars="3"/> </mx:VBox> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Birth Year"/> <mx:TextInput id="birthDay" restrict="0-9\-" maxChars="10"/> </mx:VBox> <mx:VBox> <mx:Button id="commitButton" label="Submit" click="submit();"/> </mx:VBox> </mx:Application>
Comments:
1) Validator are defined in <fx:Declarations> tag.
2) By default, the property 'required' is true, that means the field associated with the validator mustn't be left blank.
3) Validator calls validate() by default when the validated field valueCommit.
4) 'Source' and 'Property' in <mx:XXXValidator> means that the validator is statically bind to the source.property.
2. A simple example for dynamic bind validator
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600" creationComplete="init();"> <fx:Declarations> <mx:StringValidator id="usernameValidator"/> <mx:NumberValidator id="intValidator" domain="int" maxValue="150" minValue="0" valid="handleValidate(event);" invalid="handleValidate(event);"/> <mx:DateValidator id="birthDayValidator" inputFormat="YYYY-MM-DD"/> </fx:Declarations> <fx:Script> <![CDATA[ import mx.controls.Alert; import mx.events.ValidationResultEvent; import mx.validators.Validator; private var validateSucceed:Boolean = false; protected function init():void { usernameValidator.source = username; usernameValidator.property = "text"; birthDayValidator.source = birthDay; birthDayValidator.property = "text"; } protected function intFocusInHandler(event:FocusEvent):void { intValidator.source = event.currentTarget; intValidator.property = "text"; } protected function handleValidate(event:ValidationResultEvent):void { if(event.type == ValidationResultEvent.VALID) submitButton.enabled = true; else submitButton.enabled = false; } private function submit():void { var validationResult:Array = Validator.validateAll([usernameValidator, birthDayValidator]); if (validationResult.length != 0) { Alert.show("Validate error!"); } else { Alert.show("Validate succeed!"); } } ]]> </fx:Script> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Name"/> <mx:TextInput id="username"/> </mx:VBox> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Age"/> <mx:TextInput id="age" restrict="0-9" maxChars="3" focusIn="intFocusInHandler(event);"/> </mx:VBox> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Score"/> <mx:TextInput id="score" restrict="0-9" maxChars="3" focusIn="intFocusInHandler(event);"/> </mx:VBox> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="Birth Year"/> <mx:TextInput id="birthDay" restrict="0-9\-" maxChars="10"/> </mx:VBox> <mx:VBox> <mx:Button id="submitButton" label="Submit" click="submit();"/> </mx:VBox> </mx:Application>
Comments:
1) Method handled defined in property 'valid' and 'invalid' are invoked after validating the source.property associated with the validator.
We can use this property to enable or disable specific button.
2) The validator comes to effective by default when specific element valueCommit.
3) We can change the source and property in program dynamically so that we can validate a couple of elements with only one single validator.
3. Customize Validator
package view { import mx.validators.ValidationResult; import mx.validators.Validator; public class CobDateValidator extends Validator { // Define Array for the return value of doValidation(). private var results:Array; // Constructor. public function CobDateValidator() { // Call base class constructor. super(); } // Define the doValidation() method. override protected function doValidation(value:Object):Array { // Clear results Array. results = []; // Call base class doValidation(). results = super.doValidation(value); // Return if there are errors. if (results.length > 0) return results; // If input value contains no value, // issue a validation error. if ( !value ) { results.push(new ValidationResult(true, null, "NaN", "You must enter cob date.")); return results; } var year:String = (value as String).substr(0, 4); var month:String = (value as String).substr(4, 2); var day:String = (value as String).substr(6, 2); var endDate:Date = new Date(year, month, 0); var endDay:String = endDate.getDate().toString(); // If the input day is not the end day of month, issue a validation error. if (endDay != day) { results.push(new ValidationResult(true, null, "Error", "Incorrect cob date")); return results; } return results; } } }
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" xmlns:ui="view.*" minWidth="955" minHeight="600"> <fx:Declarations> <ui:CobDateValidator id="cobDateValidator" source="{cobDate}" property="text"/> </fx:Declarations> <fx:Script> <![CDATA[ import mx.controls.Alert; import mx.events.ValidationResultEvent; import mx.validators.Validator; private var validateSucceed:Boolean = false; private function submit():void { var validationResult:Array = Validator.validateAll([cobDateValidator]); if (validationResult.length != 0) { Alert.show("Validate error!"); } else { Alert.show("Validate succeed!"); } } ]]> </fx:Script> <mx:VBox> <mx:Label fontSize="12" paddingLeft="2" paddingTop="2" text="COB Date"/> <mx:TextInput id="cobDate"/> </mx:VBox> <mx:VBox> <mx:Button id="submitButton" label="Submit" click="submit();"/> </mx:VBox> </mx:Application>
Comments:
1) This validator can be used as an enhanced date validator that only the last day of the month is valid.
Reference Links:
1) http://livedocs.adobe.com/flex/3/html/help.html?content=validators_3.html
相关推荐
电动车上牌管理系统 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B
tornado-6.1-cp39-cp39-manylinux2010_x86_64.whl
一、项目简介 本项目是一套基于Java Swing 开发的网吧管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者。 包含:项目源码、数据库脚本等,该项目附带全部源码可作为毕设使用。 项目都经过严格调试,确保可以运行! 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 二、技术实现 后台技术:java swing 数据库:MySQL 数据库连接池:c3p0 三、系统主要功能 用户登录: 分为 普通用户和管理员 两种角色 菜单模块:上机,下机, 系统设置:管理员设置,会员设置,计费设置, 退出系统 管理模块:增加会员,删除会员,信息修改,信息查询 视图模块:主页视图,在线用户,统计视图, 统计报表模块:人数报表,收入报表 帮助模块:联系我们,关于系统 详见:https://blog.csdn.net/weixin_43860634/article/details/125247764
使用软件自带的basic脚本编辑制作的脚本 低版本软件无法输出Excel报告,可以通过脚本方式实现这一功能
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
基于java的网上电子书店h答辩PPT.pptx
基于微信小程序的微信小程序校园失物招领答辩PPT.pptx
基于java的基于Java的学生综合测评管理系统答辩PPT.pptx
pandas whl安装包,对应各个python版本和系统(具体看资源名字),找准自己对应的下载即可! 下载后解压出来是已.whl为后缀的安装包,进入终端,直接pip install pandas-xxx.whl即可,非常方便。 再也不用担心pip联网下载网络超时,各种安装不成功的问题。
去
管理员功能: 用户管理:管理员可以管理用户账户,包括审核新注册用户、禁用违规用户、重置密码等操作。 器材管理:管理员可以管理器材的信息,包括添加新器材、编辑器材详情、设定器材规则和限制等。 器材预约与借还管理:管理员可以处理用户的器材预约请求,确认或调整预约时间,并记录借还操作。 库存管理:管理员可以监控器材库存情况,及时补充不足的器材并处理损坏或报废的器材。 数据统计与报表:管理员可以分析系统的使用情况和借还记录,生成数据统计报表以了解器材使用情况和借还频率等。 系统设置与维护:管理员可以进行系统设置,包括配置器材规则、设定可用时间段、备份数据、优化系统性能等。 消息通知与提醒:管理员可以向用户发送消息通知,如器材预约成功、归还提醒、系统更新通知等。
Jira插件安装包Dynamic-forms
pandas whl安装包,对应各个python版本和系统(具体看资源名字),找准自己对应的下载即可! 下载后解压出来是已.whl为后缀的安装包,进入终端,直接pip install pandas-xxx.whl即可,非常方便。 再也不用担心pip联网下载网络超时,各种安装不成功的问题。
Scratch是一款由麻省理工学院(MIT)的“终身幼儿园团队”开发的图形化编程工具,专为儿童设计,旨在帮助他们学习编程思维和逻辑能力。
基于java的学生就业管理系统答辩PPT.pptx
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac
随着社会对志愿服务活动的日益重视,各大高校也纷纷参与到志愿服务的行列中。为了更好地管理和记录志愿者活动,提高志愿服务的质量和效率,我们开发了这款大学志愿服务系统。 该系统主要包括多个功能模块,如信息管理、活动管理、学生管理等。信息管理模块允许学校管理员录入、修改和删除学校的基本信息,包括学校账号、名称、联系电话、地址、特色以及办学理念等,确保信息的准确性和完整性。活动管理模块则用于记录和管理志愿者活动的相关信息,包括活动的名称、时间、地点、参与人员等,方便志愿者进行报名和签到。 此外,系统还提供了学生管理模块,用于记录学生的志愿服务经历和表现,为学生参与志愿服务提供便利。同时,系统还支持照片上传和展示功能,通过展示志愿者活动的照片,让更多人了解和关注志愿服务事业。 整个系统界面简洁明了,操作便捷,功能强大。通过使用该系统,高校可以更加高效地管理和记录志愿者活动,提高志愿服务的整体水平。同时,该系统也为广大志愿者提供了一个展示自我、服务社会的平台。
turbo均衡算法研究
https://blog.csdn.net/aggs1990/article/details/143491823 静态编译的Qt6.7.3(win10+MSVC2022+openssl+静态运行时) 压缩包比较大,这是第一部分
tornado-6.4b1-cp38-abi3-musllinux_1_1_i686.whl