0

我正在尝试使用 JSONP 和 MooTools 构建自定义 StackOverflow 徽章。这是代码:

new Request.JSONP('http://stackoverflow.com/users/flair/166325.json', {
  onComplete: function(data) {
    console.log(data);
  }
}).request();

但是,我总是会收到此消息:

RequestJSONPrequest_maprequest_0 is not defined

我想知道这是否是来自 StackOverflow 的响应的问题,因为使用 JSONP 对其他服务的请求对我来说工作正常。

4

2 回答 2

1

找到了解决方法:http: //www.jsfiddle.net/CRdr6/1/

通过将 callbackKey: "callback=myfunc&foo" 传递给 Request.JSONP 类(它没有正确转义),您可以使用 myfunc 作为全局函数来处理回调并绕过剥离.

Request.stackoverflow = new Class({
    Extends: Request.JSONP,
    options: {
        log: true,
        url: "http://stackoverflow.com/users/flair/{user}.json",
        callbackKey: "callback=myfunc&foo"
    },
    initialize: function(user, options) {
        this.parent(options);
        this.options.url = this.options.url.substitute({user: user});
    },
    success: function(data, script) {
        this.parent(data, script);
    }
});


window.myfunc = function(data) {
    console.log(data);
};

new Request.stackoverflow(166325).send();
于 2010-03-01T21:32:35.003 回答
0

我最终创建了 StackOverflow 最终调用的函数(没有点):

var StackOverflow = Class.refactor(JsonP, {
  getScript: function(options) {
    var index = Request.JSONP.counter;
    var script = this.previous(options);
    eval("RequestJSONPrequest_maprequest_" + index + " = Request.JSONP.request_map['request_' + index];");
    return script;
  }
});
于 2010-03-02T04:51:05.997 回答