Possible Duplicate:
Return Value from inside of $.ajax() function
Take the following function for example:
function($data) {
$.post(
url,
{
'data': $data
},
function(response){
return response;
}
);
}
How could I make the parent function: function($data) { ... }
return response
?
I am unable to put my the rest of my logic into the post callback due to the nature of my script. (see below)
var methods = {
'email' : function(field) {
var value = field.val();
var response = false;
field.addClass("loading");
$.post(
ajaxData.url,
{
'action':'validate_form',
'value': value,
'method': field.data('method')
},
function(response){
return response;
}
).complete(function() {
field.removeClass("loading");
});
},
'password' : function(field) {
var value = field.val();
var response = {};
if (value.length < 8) {
response.result = false;
response.message = 'Your password must be a minimum of 8 characters';
} else {
response.result = true;
response.message = false;
}
return response;
},
'verify_password' : function(field, dependancies) {
var value = field.val();
var response = {};
if (value != dependancies["password"].val()) {
if (!dependancies["password"].val() || !value) {
return false;
}
response.result = false;
response.message = 'Passwords do no match';
} else {
response.result = true;
response.message = false;
}
return response;
}
}
Where each property of methods
is a function which may be called and the return
value is used later in the script.
var response = methods[field.data('method')](field, field.data('dependancies'));