質問

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

しかし、どちらも機能していません。 nullを返します。

役に立ちましたか?

解決

String.prototype.getLanguage()関数がJSONを返すように、同期イベントを使用することを想定しています。残念ながら、リモートAPIからjQueryを使用してそれを行うことはできません。

jQueryはXMLXMLRequestの同期をサポートしていません。 同じ起源ポリシー

ただし、jQueryの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