WebWork adds support for client-side validation on top of XWork's standard validation framework. Any validator can be extended to support client-side validation by implementing the com.opensymphony.webwork.validators.ScriptValidationAware interface:
public interface ScriptValidationAware extends FieldValidator { public String validationScript(Map parameters); }
The value returned by validationScript will be executed on the client-side before the form is submitted if client-side validation is enabled. For example, the requiredstring validator has the following code:
public String validationScript(Map parameters) { String field = (String) parameters.get("name"); StringBuffer js = new StringBuffer(); js.append("value = form.elements['" + field + "'].value;\n"); js.append("if (value == \"\") {\n"); js.append("\talert('" + getMessage(null) + "');\n"); js.append("\treturn '" + field + "';\n"); js.append("}\n"); js.append("\n"); return js.toString(); }
To enable client-side validation, first make sure you have defined the correct validators in validators.xml. You must be using the com.opensymphony.webwork.validators.JavaScriptRequired*Validator instead of the standard XWork validators. Then, when you specify the <ww:form> tag, add validate="true":
<ww:form name="'test'" action="'javascriptValidation'" validate="true" > ... </ww:form>
Currently only JavaScript is supported.