mx.validators
public class NumberValidator
继承NumberValidator Inheritance Validator Inheritance EventDispatcher Inheritance Object

NumberValidator 类确保字符串表示有效数字。它可确保输入处于给定范围(由 minValuemaxValue 指定)内,是整数(由 domain 指定),为非负值(由 allowNegative 指定)并且不超过指定的 precision。验证程序可正确验证带格式的数字(例如,“12,345.67”),并且您可以自定义 thousandsSeparatordecimalSeparator 属性以实现国际化。

MXML 语法expanded隐藏 MXML 语法

The <mx:NumberValidator> tag inherits all of the tag attributes of its superclass, and adds the following tag attributes:

  <mx:NumberValidator 
    allowNegative="true|false" 
    decimalPointCountError="The decimal separator can only occur once." 
    decimalSeparator="." 
    domain="real|int" 
    exceedsMaxError="The number entered is too large." 
    integerError="The number must be an integer." 
    invalidCharError="The input contains invalid characters." 
    invalidFormatCharsError="One of the formatting parameters is invalid." 
    lowerThanMinError="The amount entered is too small." 
    maxValue="NaN" 
    minValue="NaN" 
    negativeError="The amount may not be negative." 
    precision="-1" 
    precisionError="The amount entered has too many digits beyond the decimal point." 
    separationError="The thousands separator must be followed by three digits." 
    thousandsSeparator="," 
  />
  

查看示例



公共属性
 属性定义方
  allowNegative : Object
指定是否允许为负数。
NumberValidator
 Inheritedconstructor : Object
对类对象或给定对象实例的构造函数的引用。
Object
  decimalPointCountError : String
多次出现小数分隔符时的错误消息。
NumberValidator
  decimalSeparator : String
用于分隔数字的整数部分和小数部分的字符。
NumberValidator
  domain : String
要验证的数字类型。
NumberValidator
 Inheritedenabled : Boolean
将此值设置为 false 将停止验证程序执行验证操作。
Validator
  exceedsMaxError : String
值超过 maxValue 属性时的错误消息。
NumberValidator
  integerError : String
数字必须为整数(如 domain 属性所定义)时的错误消息。
NumberValidator
  invalidCharError : String
值包含无效字符时的错误消息。
NumberValidator
  invalidFormatCharsError : String
值包含无效格式字符(这意味着它包含数字或负号 (-) 作为分隔符,或者它包含两个或多个连续分隔符)时的错误消息。
NumberValidator
 Inheritedlistener : Object
指定验证侦听器。
Validator
  lowerThanMinError : String
值小于 minValue 时的错误消息。
NumberValidator
  maxValue : Object
有效数字的最大值。
NumberValidator
  minValue : Object
有效数字的最小值。
NumberValidator
  negativeError : String
值为负且 allowNegative 属性为 false 时的错误消息。
NumberValidator
  precision : Object
小数点后允许的最大位数。
NumberValidator
  precisionError : String
值的精度超过 precision 属性所定义值时的错误消息。
NumberValidator
 Inheritedproperty : String
一个字符串,用于指定包含要验证的值的 source 对象的属性名称。
Validator
 Inheritedprototype : Object
[静态] 对类或函数对象的原型对象的引用。
Object
 Inheritedrequired : Boolean = true
如果为 true,则指定缺少值或空值将导致验证错误。
Validator
 InheritedrequiredFieldError : String
缺少值和 required 属性为 true 时的错误消息。
Validator
  separationError : String
千分位分隔符所处位置不当时的错误消息。
NumberValidator
 Inheritedsource : Object
指定包含要验证的属性的对象。
Validator
  thousandsSeparator : String
用于在数字的整数部分中分隔千分位的字符。
NumberValidator
 Inheritedtrigger : IEventDispatcher
指定生成触发验证程序的组件。
Validator
 InheritedtriggerEvent : String
指定触发验证的事件。
Validator
受保护的属性
 属性定义方
 InheritedactualListeners : Array
[只读 (read-only)] 包含侦听器对象(如果有)的数组或源对象。
Validator
 InheritedactualTrigger : IEventDispatcher
[只读 (read-only)] 包含触发器对象(如果有)或源对象。
Validator
 InheritedresourceManager : IResourceManager
[只读 (read-only)] 引用管理所有应用程序本地化资源的对象。
Validator
 InheritedsubFields : Array
一个字符串数组,其中包含传递到 validate() 方法的 value 对象中所含属性的名称。
Validator
公共方法
 方法定义方
  
构造函数。
NumberValidator
 Inherited
addEventListener(type:String, listener:Function, useCapture:Boolean = false, priority:int = 0, useWeakReference:Boolean = false):void
使用 EventDispatcher 对象注册事件侦听器对象,以使侦听器能够接收事件通知。
EventDispatcher
 Inherited
将事件调度到事件流中。
EventDispatcher
 Inherited
检查 EventDispatcher 对象是否为特定事件类型注册了任何侦听器。
EventDispatcher
 Inherited
指示对象是否已经定义了指定的属性。
Object
 Inherited
如果 Validator 是使用 MXML 标签创建的,则由 MXML 编译器自动调用。
Validator
 Inherited
指示 Object 类的实例是否在指定为参数的对象的原型链中。
Object
 Inherited
指示指定的属性是否存在、是否可枚举。
Object
 Inherited
removeEventListener(type:String, listener:Function, useCapture:Boolean = false):void
从 EventDispatcher 对象中删除侦听器。
EventDispatcher
 Inherited
设置循环操作动态属性的可用性。
Object
 Inherited
返回指定对象的字符串表示形式。
Object
 Inherited
validate(value:Object = null, suppressEvents:Boolean = false):ValidationResultEvent
执行验证并(可选)将结果通知给侦听器。
Validator
 Inherited
validateAll(validators:Array):Array
[静态] 调用验证程序数组中的所有验证程序。
Validator
  
validateNumber(validator:NumberValidator, value:Object, baseField:String):Array
[静态] 用于从自定义验证函数内调用验证程序的方便方法。
NumberValidator
 Inherited
返回指定对象的原始值。
Object
 Inherited
检查是否用此 EventDispatcher 对象或其任何始祖为指定事件类型注册了事件侦听器。
EventDispatcher
受保护的方法
 方法定义方
 Inherited
为从验证程序调度的有效和无效事件设置所有侦听器。
Validator
  
覆盖基类 doValidation() 方法以验证数字。
NumberValidator
 Inherited
返回要验证的对象。
Validator
 Inherited
从错误结果数组返回 ValidationResultEvent。
Validator
 Inherited
如果值不为 null,则返回 true。
Validator
 Inherited
断开从验证程序调度的有效和无效事件的所有侦听器的连接。
Validator
 Inherited
构造 Validator 后,每当 ResourceManager 又调度一个“change”事件以指示已通过某种方式更改了本地化资源时,将会调用此方法。
Validator
事件
 事件 摘要 定义方
 Inherited[广播事件] Flash Player 或 AIR 应用程序获得操作系统焦点并变为活动状态时将调度此事件。EventDispatcher
 Inherited[广播事件] Flash Player 或 AIR 应用程序失去操作系统焦点并变为非活动状态时将调度此事件。EventDispatcher
 Inherited在验证失败时调度。Validator
 Inherited在验证成功时调度。Validator
受保护的常量
 常量定义方
 InheritedDECIMAL_DIGITS : String = "0123456789"
[静态] 包含十进制数字 0 到 9 的字符串。
Validator
 InheritedROMAN_LETTERS : String = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
[静态] 包含大写和小写罗马字母(“A”到“Z”和“a”到“z”)的字符串。
Validator
属性详细信息
allowNegative属性
allowNegative:Object  [读写]

指定是否允许为负数。有效值为 truefalse

默认值为 true.



实现
    public function get allowNegative():Object
    public function set allowNegative(value:Object):void
decimalPointCountError属性 
decimalPointCountError:String  [读写]

多次出现小数分隔符时的错误消息。

默认值为 "The decimal separator can occur only once.".



实现
    public function get decimalPointCountError():String
    public function set decimalPointCountError(value:String):void
decimalSeparator属性 
decimalSeparator:String  [读写]

用于分隔数字的整数部分和小数部分的字符。不能是数字且必须有别于 thousandsSeparator

默认值为 ".".



实现
    public function get decimalSeparator():String
    public function set decimalSeparator(value:String):void
domain属性 
domain:String  [读写]

要验证的数字类型。允许的值为 "real""int"

默认值为 "real".



实现
    public function get domain():String
    public function set domain(value:String):void
exceedsMaxError属性 
exceedsMaxError:String  [读写]

值超过 maxValue 属性时的错误消息。

默认值为 "The number entered is too large.".



实现
    public function get exceedsMaxError():String
    public function set exceedsMaxError(value:String):void
integerError属性 
integerError:String  [读写]

数字必须为整数(如 domain 属性所定义)时的错误消息。

默认值为 "The number must be an integer.".



实现
    public function get integerError():String
    public function set integerError(value:String):void
invalidCharError属性 
invalidCharError:String  [读写]

值包含无效字符时的错误消息。

默认值为 The input contains invalid characters.".



实现
    public function get invalidCharError():String
    public function set invalidCharError(value:String):void
invalidFormatCharsError属性 
invalidFormatCharsError:String  [读写]

值包含无效格式字符(这意味着它包含数字或负号 (-) 作为分隔符,或者它包含两个或多个连续分隔符)时的错误消息。

默认值为 "One of the formatting parameters is invalid.".



实现
    public function get invalidFormatCharsError():String
    public function set invalidFormatCharsError(value:String):void
lowerThanMinError属性 
lowerThanMinError:String  [读写]

值小于 minValue 时的错误消息。

默认值为 "The amount entered is too small.".



实现
    public function get lowerThanMinError():String
    public function set lowerThanMinError(value:String):void
maxValue属性 
maxValue:Object  [读写]

有效数字的最大值。值为 NaN 表示没有最大值。

默认值为 NaN.



实现
    public function get maxValue():Object
    public function set maxValue(value:Object):void
minValue属性 
minValue:Object  [读写]

有效数字的最小值。值为 NaN 表示没有最小值。

默认值为 NaN.



实现
    public function get minValue():Object
    public function set minValue(value:Object):void
negativeError属性 
negativeError:String  [读写]

值为负且 allowNegative 属性为 false 时的错误消息。

默认值为 "The amount may not be negative.".



实现
    public function get negativeError():String
    public function set negativeError(value:String):void
precision属性 
precision:Object  [读写]

小数点后允许的最大位数。可以为任何非负整数。注意:设置为 0 与将 domain 设置为 "int" 效果相同。值为 -1 表示忽略此属性。

默认值为 -1.



实现
    public function get precision():Object
    public function set precision(value:Object):void
precisionError属性 
precisionError:String  [读写]

值的精度超过 precision 属性所定义值时的错误消息。

默认值为 "The amount entered has too many digits beyond the decimal point.".



实现
    public function get precisionError():String
    public function set precisionError(value:String):void
separationError属性 
separationError:String  [读写]

千分位分隔符所处位置不当时的错误消息。

默认值为 "The thousands separator must be followed by three digits.".



实现
    public function get separationError():String
    public function set separationError(value:String):void
thousandsSeparator属性 
thousandsSeparator:String  [读写]

用于在数字的整数部分中分隔千分位的字符。不能是数字且必须有别于 decimalSeparator

默认值为 ",".



实现
    public function get thousandsSeparator():String
    public function set thousandsSeparator(value:String):void
构造函数详细信息
NumberValidator()构造函数
public function NumberValidator()

构造函数。

方法详细信息
doValidation()方法
override protected function doValidation(value:Object):Array

覆盖基类 doValidation() 方法以验证数字。

不要直接调用此方法;Flex 会在执行验证的过程中调用它。如果创建自定义 Validator 类,则必须实现此方法。

参数

value:Object — 要验证的对象。

返回
Array — ValidationResult 对象的数组,验证程序检查的每个字段都有一个 ValidationResult 对象。
validateNumber()方法 
public static function validateNumber(validator:NumberValidator, value:Object, baseField:String):Array

用于从自定义验证函数内调用验证程序的方便方法。每个标准 Flex 验证程序都有一个类似的方便方法。

参数

validator:NumberValidator — NumberValidator 实例。
 
value:Object — 要验证的字段。
 
baseField:String — 在 value 参数中指定的子字段的文本表示形式。例如,如果 value 参数指定 value.number,则 baseField 值为“number”。

返回
Array — ValidationResult 对象的数组,验证程序检查的每个字段都有一个 ValidationResult 对象。

另请参见

示例 如何使用示例
NumberValidatorExample.mxml
<?xml version="1.0" encoding="utf-8"?>
<!-- Simple example to demonstrate the NumberValidator. -->
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">

    <mx:Script>
        import mx.controls.Alert;
    </mx:Script>

    <mx:NumberValidator source="{age}" property="text" integerError="Enter Integer value"
        minValue="18" maxValue="50" domain="int" 
        trigger="{myButton}" triggerEvent="click"
        valid="Alert.show('Validation Succeeded!');"/>

    <mx:Panel title="NumberValidator Example" width="75%" height="75%" 
        paddingTop="10" paddingLeft="10" paddingRight="10" paddingBottom="10">

        <mx:Form>
            <mx:FormItem label="Enter an age between 18 and 50: ">
                <mx:TextInput id="age" width="100%"/>
            </mx:FormItem>

            <mx:FormItem >
                <mx:Button id="myButton" label="Validate" />
            </mx:FormItem>
        </mx:Form>
    </mx:Panel>
</mx:Application>