包 | mx.validators |
类 | public class CurrencyValidator |
继承 | CurrencyValidator Validator EventDispatcher Object |
minValue
和 maxValue
指定)内,为非负值(由 allowNegative
指定)并且不超过指定的 precision
。CurrencyValidator 类可正确验证带格式和无格式的货币表达式,例如,“$12,345.00”和“12345”。您可以自定义 currencySymbol
、alignSymbol
、thousandsSeparator
和 decimalSeparator
属性以实现国际化。
MXML 语法隐藏 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="," />
另请参见
属性 | 定义方 | ||
---|---|---|---|
alignSymbol : String 指定 currencySymbol 相对于其余表达式的对齐方式。 | CurrencyValidator | ||
allowNegative : Object 指定是否允许为负数。 | CurrencyValidator | ||
constructor : Object
对类对象或给定对象实例的构造函数的引用。 | Object | ||
currencySymbol : String 用于指定货币符号(如“$”、“R$”或“£”)的字符 String。 | CurrencyValidator | ||
currencySymbolError : String currencySymbol 所定义的货币符号所处位置不当时的错误消息。 | CurrencyValidator | ||
decimalPointCountError : String 多次出现小数分隔符时的错误消息。 | CurrencyValidator | ||
decimalSeparator : String 用于分隔数字的整数部分和小数部分的字符。 | CurrencyValidator | ||
enabled : Boolean 将此值设置为 false 将停止验证程序执行验证操作。 | Validator | ||
exceedsMaxError : String 值大于 maxValue 时的错误消息。 | CurrencyValidator | ||
invalidCharError : String 货币包含无效字符时的错误消息。 | CurrencyValidator | ||
invalidFormatCharsError : String 值包含的格式化字符无效时的错误消息。 | CurrencyValidator | ||
listener : Object 指定验证侦听器。 | Validator | ||
lowerThanMinError : String 值小于 minValue 时的错误消息。 | CurrencyValidator | ||
maxValue : Object 有效数字的最大值。 | CurrencyValidator | ||
minValue : Object 有效数字的最小值。 | CurrencyValidator | ||
negativeError : String 值为负且 allowNegative 属性为 false 时的错误消息。 | CurrencyValidator | ||
precision : Object 小数点后允许的最大位数。 | CurrencyValidator | ||
precisionError : String 值的精度超过 precision 属性所定义值时的错误消息。 | CurrencyValidator | ||
property : String 一个字符串,用于指定包含要验证的值的 source 对象的属性名称。 | Validator | ||
prototype : Object [静态]
对类或函数对象的原型对象的引用。 | Object | ||
required : Boolean = true 如果为 true,则指定缺少值或空值将导致验证错误。 | Validator | ||
requiredFieldError : String 缺少值和 required 属性为 true 时的错误消息。 | Validator | ||
separationError : String 千分位分隔符置于不正确位置时的错误消息。 | CurrencyValidator | ||
source : Object 指定包含要验证的属性的对象。 | Validator | ||
thousandsSeparator : String 用于分隔千分位的字符。 | CurrencyValidator | ||
trigger : IEventDispatcher 指定生成触发验证程序的组件。 | Validator | ||
triggerEvent : String 指定触发验证的事件。 | Validator |
方法 | 定义方 | ||
---|---|---|---|
构造函数。 | CurrencyValidator | ||
addEventListener(type:String, listener:Function, useCapture:Boolean = false, priority:int = 0, useWeakReference:Boolean = false):void 使用 EventDispatcher 对象注册事件侦听器对象,以使侦听器能够接收事件通知。 | EventDispatcher | ||
将事件调度到事件流中。 | EventDispatcher | ||
检查 EventDispatcher 对象是否为特定事件类型注册了任何侦听器。 | EventDispatcher | ||
指示对象是否已经定义了指定的属性。 | Object | ||
如果 Validator 是使用 MXML 标签创建的,则由 MXML 编译器自动调用。 | Validator | ||
指示 Object 类的实例是否在指定为参数的对象的原型链中。 | Object | ||
指示指定的属性是否存在、是否可枚举。 | Object | ||
从 EventDispatcher 对象中删除侦听器。 | EventDispatcher | ||
设置循环操作动态属性的可用性。 | Object | ||
返回指定对象的字符串表示形式。 | Object | ||
执行验证并(可选)将结果通知给侦听器。 | Validator | ||
[静态] 调用验证程序数组中的所有验证程序。 | Validator | ||
[静态] 用于调用验证程序的方便方法。 | CurrencyValidator | ||
返回指定对象的原始值。 | Object | ||
检查是否用此 EventDispatcher 对象或其任何始祖为指定事件类型注册了事件侦听器。 | EventDispatcher |
方法 | 定义方 | ||
---|---|---|---|
为从验证程序调度的有效和无效事件设置所有侦听器。 | Validator | ||
覆盖基类 doValidation() 方法以验证货币表达式。 | CurrencyValidator | ||
返回要验证的对象。 | Validator | ||
从错误结果数组返回 ValidationResultEvent。 | Validator | ||
如果值不为 null,则返回 true。 | Validator | ||
断开从验证程序调度的有效和无效事件的所有侦听器的连接。 | Validator | ||
构造 Validator 后,每当 ResourceManager 又调度一个“change”事件以指示已通过某种方式更改了本地化资源时,将会调用此方法。 | Validator |
alignSymbol | 属性 |
alignSymbol:String
[读写]
指定 currencySymbol
相对于其余表达式的对齐方式。ActionScript 中的可接受的值为 CurrencyValidatorAlignSymbol.LEFT
、CurrencyValidatorAlignSymbol.RIGHT
和 CurrencyValidatorAlignSymbol.ANY
。MXML 中的可接受的值为 "left"
、"right"
和 "any"
。
默认值为 CurrencyValidatorAlignSymbol.LEFT.
public function get alignSymbol():String
public function set alignSymbol(value:String):void
另请参见
allowNegative | 属性 |
allowNegative:Object
[读写]
指定是否允许为负数。可以为 true
或 false
。
默认值为 true.
public function get allowNegative():Object
public function set allowNegative(value:Object):void
currencySymbol | 属性 |
currencySymbol:String
[读写]
用于指定货币符号(如“$”、“R$”或“£”)的字符 String。不能是数字且必须有别于 thousandsSeparator
和 decimalSeparator
。
默认值为 "$".
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
[读写]
用于分隔数字的整数部分和小数部分的字符。不能是数字且必须有别于 currencySymbol
和 thousandsSeparator
。
默认值为 ".".
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
[读写]
用于分隔千分位的字符。不能是数字且必须有别于 currencySymbol
和 decimalSeparator
。
默认值为 ",".
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 对象。 |
另请参见
<?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>