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元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
