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

CurrencyValidator 类确保字符串表示有效货币表达式。它可确保输入处于给定范围(由 minValuemaxValue 指定)内,为非负值(由 allowNegative 指定)并且不超过指定的 precision。CurrencyValidator 类可正确验证带格式和无格式的货币表达式,例如,“$12,345.00”和“12345”。您可以自定义 currencySymbolalignSymbolthousandsSeparatordecimalSeparator 属性以实现国际化。

MXML 语法expanded隐藏 MXML 语法

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

  <mx:CurrencyValidator
    alignSymbol="left|right|any"
    allowNegative="true|false"
    currencySymbol="$"
    currencySymbolError="The currency symbol occurs in an invalid location."
    decimalPointCountError="The decimal separator can occur only once."
    decimalSeparator="."
    exceedsMaxError="The amount entered is too large."
    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="2"
    precisionError="The amount entered has too many digits beyond the decimal point."
    separationError="The thousands separator must be followed by three digits."
    thousandsSeparator=","
  />
  

查看示例

另请参见

mx.validators.CurrencyValidatorAlignSymbol


公共属性
 属性定义方
  alignSymbol : String
指定 currencySymbol 相对于其余表达式的对齐方式。
CurrencyValidator
  allowNegative : Object
指定是否允许为负数。
CurrencyValidator
 Inheritedconstructor : Object
对类对象或给定对象实例的构造函数的引用。
Object
  currencySymbol : String
用于指定货币符号(如“$”、“R$”或“£”)的字符 String。
CurrencyValidator
  currencySymbolError : String
currencySymbol 所定义的货币符号所处位置不当时的错误消息。
CurrencyValidator
  decimalPointCountError : String
多次出现小数分隔符时的错误消息。
CurrencyValidator
  decimalSeparator : String
用于分隔数字的整数部分和小数部分的字符。
CurrencyValidator
 Inheritedenabled : Boolean
将此值设置为 false 将停止验证程序执行验证操作。
Validator
  exceedsMaxError : String
值大于 maxValue 时的错误消息。
CurrencyValidator
  invalidCharError : String
货币包含无效字符时的错误消息。
CurrencyValidator
  invalidFormatCharsError : String
值包含的格式化字符无效时的错误消息。
CurrencyValidator
 Inheritedlistener : Object
指定验证侦听器。
Validator
  lowerThanMinError : String
值小于 minValue 时的错误消息。
CurrencyValidator
  maxValue : Object
有效数字的最大值。
CurrencyValidator
  minValue : Object
有效数字的最小值。
CurrencyValidator
  negativeError : String
值为负且 allowNegative 属性为 false 时的错误消息。
CurrencyValidator
  precision : Object
小数点后允许的最大位数。
CurrencyValidator
  precisionError : String
值的精度超过 precision 属性所定义值时的错误消息。
CurrencyValidator
 Inheritedproperty : String
一个字符串,用于指定包含要验证的值的 source 对象的属性名称。
Validator
 Inheritedprototype : Object
[静态] 对类或函数对象的原型对象的引用。
Object
 Inheritedrequired : Boolean = true
如果为 true,则指定缺少值或空值将导致验证错误。
Validator
 InheritedrequiredFieldError : String
缺少值和 required 属性为 true 时的错误消息。
Validator
  separationError : String
千分位分隔符置于不正确位置时的错误消息。
CurrencyValidator
 Inheritedsource : Object
指定包含要验证的属性的对象。
Validator
  thousandsSeparator : String
用于分隔千分位的字符。
CurrencyValidator
 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
公共方法
 方法定义方
  
构造函数。
CurrencyValidator
 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
  
[静态] 用于调用验证程序的方便方法。
CurrencyValidator
 Inherited
返回指定对象的原始值。
Object
 Inherited
检查是否用此 EventDispatcher 对象或其任何始祖为指定事件类型注册了事件侦听器。
EventDispatcher
受保护的方法
 方法定义方
 Inherited
为从验证程序调度的有效和无效事件设置所有侦听器。
Validator
  
覆盖基类 doValidation() 方法以验证货币表达式。
CurrencyValidator
 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
属性详细信息
alignSymbol属性
alignSymbol:String  [读写]

指定 currencySymbol 相对于其余表达式的对齐方式。ActionScript 中的可接受的值为 CurrencyValidatorAlignSymbol.LEFTCurrencyValidatorAlignSymbol.RIGHTCurrencyValidatorAlignSymbol.ANY。MXML 中的可接受的值为 "left""right""any"

默认值为 CurrencyValidatorAlignSymbol.LEFT.



实现
    public function get alignSymbol():String
    public function set alignSymbol(value:String):void

另请参见

allowNegative属性 
allowNegative:Object  [读写]

指定是否允许为负数。可以为 truefalse

默认值为 true.



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

用于指定货币符号(如“$”、“R$”或“£”)的字符 String。不能是数字且必须有别于 thousandsSeparatordecimalSeparator

默认值为 "$".



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

currencySymbol 所定义的货币符号所处位置不当时的错误消息。

默认值为 "The currency symbol occurs in an invalid location.".



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

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

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



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

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

默认值为 ".".



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

值大于 maxValue 时的错误消息。

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



实现
    public function get exceedsMaxError():String
    public function set exceedsMaxError(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 与将 NumberValidator.domain 设置为 int 效果相同。将其设置为 -1 表示忽略此属性。

默认值为 2.



实现
    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  [读写]

用于分隔千分位的字符。不能是数字且必须有别于 currencySymboldecimalSeparator

默认值为 ",".



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

构造函数。

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

覆盖基类 doValidation() 方法以验证货币表达式。

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

参数

value:Object — 要验证的对象。

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

用于调用验证程序的方便方法。每个标准 Flex 验证程序都有一个类似的方便方法。

参数

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

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

另请参见

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

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

    <mx:CurrencyValidator source="{priceUS}" property="text" precision="2" 
        trigger="{myButton}" triggerEvent="click" 
        valid="Alert.show('Validation Succeeded!');"/>

    <mx:Panel title="CurrencyValidator Example" width="75%" height="75%" 
        paddingTop="10" paddingLeft="10" paddingRight="10" paddingBottom="10">
        
        <mx:Form>
            <mx:FormItem label="Enter a U.S. dollar amount: ">
                 <mx:TextInput id="priceUS" width="100%"/>
            </mx:FormItem>

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