Expand my Community achievements bar.

Join us in celebrating the outstanding achievement of our AEM Community Member of the Year!
SOLVED

Comparing length

Avatar

Level 4

Hi All,

I have a form I have just completed, and it is one of those complex one. There is a field that is numeric, and should not accept less than 4 digits. I wrote the following code, but it doesn't seem to work, and I do not know why.

if

(SSN_SMg.rawValue > "" &&  SSN_SMg.length < 4){

xfa.host.messageBox

="none";

xfa.host.setFocus("SSN_SMg");

}

Please, can someone tell me what I am doing wrong.

Thanks

LP

1 Accepted Solution

Avatar

Correct answer by
Former Community Member

I find numeric fields to be cumbersome when it comes to form validation so I use text fields and regular expressions.

Additionally, you can set the length (max characters) to control the upper limit thus avoiding an edit. So in your case, set the max characters to 4. If the field is not mandatory, check to see if it is not null. If it is entered, the regular expression checks that the value has a length of 4 and contains digits only.

if (!(form1.page1.nf1.isNull)) {

     var regExp = /^\d{4}$/;

     if (!(regExp.test(form1.page1.nf1.rawValue))) {

          xfa.host.messageBox("Please enter four digits.");

     }

}

Steve

View solution in original post

2 Replies

Avatar

Correct answer by
Former Community Member

I find numeric fields to be cumbersome when it comes to form validation so I use text fields and regular expressions.

Additionally, you can set the length (max characters) to control the upper limit thus avoiding an edit. So in your case, set the max characters to 4. If the field is not mandatory, check to see if it is not null. If it is entered, the regular expression checks that the value has a length of 4 and contains digits only.

if (!(form1.page1.nf1.isNull)) {

     var regExp = /^\d{4}$/;

     if (!(regExp.test(form1.page1.nf1.rawValue))) {

          xfa.host.messageBox("Please enter four digits.");

     }

}

Steve

Avatar

Level 4

Thanks, Steve, that approach works.

The following has evaluated to null or missing: ==> liqladmin("SELECT id, value FROM metrics WHERE id = 'net_accepted_solutions' and user.id = '${acceptedAnswer.author.id}'").data.items [in template "analytics-container" at line 83, column 41] ---- Tip: It's the step after the last dot that caused this error, not those before it. ---- Tip: If the failing expression is known to be legally refer to something that's sometimes null or missing, either specify a default value like myOptionalVar!myDefault, or use <#if myOptionalVar??>when-present<#else>when-missing. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)?? ---- ---- FTL stack trace ("~" means nesting-related): - Failed at: #assign answerAuthorNetSolutions = li... [in template "analytics-container" at line 83, column 5] ----