jQuery getJSON - Возвращает значение функции вызывающей стороны.

StackOverflow https://stackoverflow.com/questions/1229307

  •  22-07-2019
  •  | 
  •  

Вопрос

    String.prototype.getLanguage = function() {
        $.getJSON('http://ajax.googleapis.com/ajax/services/language/detect?v=1.0&q=' + this + '&callback=?',
            function(json) {
               return json.responseData.language;
            });
    };

Как я могу вернуть значение в значение вызывающего? Спасибо.

РЕДАКТИРОВАТЬ: я пробовал это

    String.prototype.getLanguage = function() {
        var returnValue = null;

        $.getJSON('http://ajax.googleapis.com/ajax/services/language/detect?v=1.0&q=' + this + '&callback=?',
            function(json) {
               returnValue = json.responseData.language;
            });

        return returnValue;
    };

Но это тоже не работает. Возвращает ноль.

Это было полезно?

Решение

Я предполагаю, что вы хотите использовать синхронное событие, чтобы ваша функция String.prototype.getLanguage () просто возвращала JSON. К сожалению, вы не можете сделать это с помощью jQuery из удаленного API.

Насколько я знаю, jQuery не поддерживает синхронного XMLHttpRequest объекты , и даже если это произойдет, вам понадобится прокси на вашем сервере, чтобы сделать запрос на синхронизацию, избегая при этом ограничений Политика одинакового происхождения .

Однако вы можете делать то, что хотите, используя поддержку JSON для JSONP. Если мы просто напишем String.prototype.getLanguage () для поддержки обратного вызова:

String.prototype.getLanguage = function( callback ) {
    var thisObj = this;
    var url = 'http://ajax.googleapis.com/ajax/services/language/detect?v=1.0&q=' + this + '&callback=?';

    $.getJSON( url,function(json) {
                callback.call(thisObj,json.responseData.language);
    });
}

Тогда мы можем использовать функцию как таковую:

'this is my string'.getLanguage( function( language ) {
    //Do what you want with the result here, but keep in mind that it is async!
    alert(this);
    alert(language);
});

Другие советы

var test = function(fun)
{

String.prototype.getLanguage = function() {
        .getJSON('http://ajax.googleapis.com/ajax/services/language/detect?v=1.0&q=' + this + '&callback=?',
            function(json) {
              fun.call(json.responseData.language);
            });
    };

};

test(retCall);

var retCall = function(xjson){
   alert(xjson);
};
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top