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

但它也不起作用。它返回空值。

4

2 回答 2

6

我假设您想使用同步事件,以便您的 String.prototype.getLanguage() 函数只返回 JSON。不幸的是,你不能通过远程 API 使用 jQuery 来做到这一点。

据我所知,jQuery 不支持同步 XMLHttpRequest 对象,即使支持,您也需要在服务器上使用代理来发出同步请求,同时避免同源策略的限制。

但是,您可以使用 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);
});
于 2009-08-04T20:48:20.890 回答
1
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);
};
于 2009-08-04T19:05:20.397 回答