0

重複の可能性:
$.ajax() 関数内からの戻り値

たとえば、次の関数を使用します。

function($data) {
    $.post(
        url,
        {
            'data': $data
        },
        function(response){
            return response;
        }
    );
}

親関数をどのように作成できますか: function($data) { ... }return response?

スクリプトの性質上、残りのロジックをポスト コールバックに入れることができません。(下記参照)

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;
        }
    }

の各プロパティmethodsは、呼び出すことができる関数であり、return値はスクリプトで後で使用されます。

var response = methods[field.data('method')](field, field.data('dependancies'));
4

1 に答える 1

2

AのAは のAJAXAsynchronousなので、好きなように戻ることはできません。以下のようなコールバック関数を試すことができます。

function($data, callback) {
    $.post(
        url,
        {
            'data': $data
        },
        function(response){
            return callback(response);
        }
    );
}

例えば:

var myObj = {
   myfunc: function($data, callback) {
        $.post(
            url,
            {
                'data': $data
            },
            function(response){
                return callback(response);
            }
        );
    }
}

myObj.myfunc($data, function(response) {
  // process here with response
});
于 2012-07-18T15:24:37.613 に答える