jQuery Validation Plugin: Setting error message for remote method
The jQuery Validation Plugin, by default, provides a way to validate fields using server-side resource via Ajax call. This is through the use of the remote rule/method.
According to the documentation (or from how I understand the stuff written about it), the script response is evaluated as a JSON. Returning true implies that the field passed validation while return values such a false, undefined or null would mean it failed. The documentation also seemed to mean that I can return a string that will be used and displayed as its error message. Good, I’m running several server side validations on a particular field. It’s best that I display the details on which validation check that field failed.
My script did return a string but it wasn’t being used by the validation plugin – no error messages are being displayed. I knew, though, that validation failed since the form did not continue to submit. The PHP snippet kinda looked like this:
==
jQuery.parseJSON() utility function. Reading the documentation for that function gave me a clue on what I was doing wrong. Echoing ‘true’ resulted to true and echoing ‘false’ resulted to false – as if the string was eval()ed. If I were to eval() ‘some string’, it would give me an error. But if I eval() ‘”some string”‘ (note the double quotes) instead, it evaluates as a string.
So, in order for my message to be parsed as string, I just wrap the output inside double quotes:
==
http://json.org/).
?????????…
[…]the time to read or visit the content or sites we have linked to below the[…]…
Hi, you may also consider this code:
header( “Content-type: text/json” );
exit( “( {result: false, /* means error */response:’ Ugh.. that is not allowed’} )” );
@zidaine_38,
Thanks for the comment. But have you tried your code? That server response format is not documented and not supported. Check the plugin source (http://ajax.aspnetcdn.com/ajax/jquery.validate/1.9/jquery.validate.js) and you will see that the format you posted is not supported. Yours is not even a well-formed JSON string to start with.
Sorry, it should be header( “Content-type: application/json” );
or header( “Content-type: text/plain” );
both will work.
And i think, it is essential for an Object Oriented Program to have a comprehensive server response, In my case i think it is good to have a response object rather than a single string. Of course it will work, but it’d be much better to organize the codes.
Ehem, it is a well-formed JSON object not a string.
Uhm this is the reference for JavaScript Object Notation Mime type:
http://www.ietf.org/rfc/rfc4627.txt
http://stackoverflow.com/questions/477816/the-right-json-content-type
It is a standard procedure to specify in the header response what kind of object/ document is passed to the clients browser. Although not specifying the content type will also work.
@zidaine_38:
I’m not sure if you are even aware of the topic I was discussing in the blog post.I’ll explain it to you hoping you’d have a better understanding of what was being discussed:
( {result: false, /* means error */response:’ Ugh.. that is not allowed’} )
So, how can you claim that the output of the code is a valid JSON string if the name identifiers you used were not enclosed in double quotes, and the string value is enclosed in single quotes? You even wrapped the object in parentheses. You even have comments inside! How did that became a well-formed JSON string? If the string is a well-formed JSON string, a modern browser’s native JSON.parse() will not have problems with it.
whatever you say ^^