Flex中對同一控件如TextInput進行多種格式校驗的情況下,如不注意,可能導致錯誤信息不顯示的BUG,比如
<
fx:Array
id
="validators"
>
<
mx:RegExpValidator
source
="{txtNewPass}"
property
="text"
required
="true"
requiredFieldError
="請輸入新密碼"
expression
="^(?:(?=.*[a-zA-Z])(?=.*[0-9])).\{8,\}$"
noMatchError
="密碼長度不少于8位,至少包含數字和字母"
/>
<
cn:CompareValidator
source
="{txtNewPass}"
property
="text"
required
="false"
comparer
="{txtOldPass.text}"
comparable
="true"
compareError
="新密碼與原密碼相同"
/>
</
fx:Array
>
這種情況下會發現txtNewPass這個TextInput的錯誤提示無法顯示,我試了很久,發現原因在于? required="true" requiredFieldError="請輸入新密碼" ,必須放在最后一個校驗器中,而 前面的必須設置required="false" ,很奇怪,算是一個小BUG了,正確寫法:
<
fx:Array
id
="validators"
>
<
mx:RegExpValidator
source
="{txtNewPass}"
property
="text"
?required
="false"
expression
="^(?:(?=.*[a-zA-Z])(?=.*[0-9])).\{8,\}$"
noMatchError
="密碼長度不少于8位,至少包含數字和字母"
/>
<
cn:CompareValidator
source
="{txtNewPass}"
property
="text" required
="true"
requiredFieldError
="請輸入新密碼"
comparer
="{txtOldPass.text}"
comparable
="true"
compareError
="新密碼與原密碼相同"
/>
</
fx:Array
>
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

