0

我一直在尝试使用 jquery 来处理跨域请求,但是尽管请求成功,但浏览器抱怨无法解析结果。我知道 JsonP 附加了一个回调参数,但是关于 SO 的所有问题都没有说明回调是如何被实际调用的。有人可以澄清 JsonP 的回调是如何执行的,并帮助我解决这个问题。

<body>
    <ul id="tweets">Test</ul>
</body>

用于此的 Javascript

        window.myCallback = function(data) {
            console.log(data);
            $("#tweets").append("<div>Hello</div>");
        };

        $(document).ready(function(){

            $.ajax({
              url: 'http://www.netflix.com',
              type: 'GET',
              dataType: 'jsonp',
              jsonp: 'callback',
              jsonpCallback: 'myCallback',
                      contentType: 'text/html',
                    success: function (data) {
                        alert(data);
                    }
            });

        });

我这里也有一个 JsFiddle http://jsfiddle.net/3yVC7/

所以在这个例子中,我只想在调用回调时修改“tweets”div,但它永远不会被调用。任何帮助将不胜感激。非常感谢。

4

2 回答 2

2

删除回调函数周围的 qoutations:

    var myCallback = function(data) {
        console.log(data);
        $("body").append("<div>Hello</div>");
    };

    $(document).ready(function(){

        $.ajax({
          url: 'http://www.google.com',
          type: 'GET',
          dataType: 'jsonp',
          jsonp: 'callback',
          jsonpCallback: myCallback,
          contentType: 'text/html',
          success: function (data) {
            alert(data);
          }
        });

    });

小提琴:点击我

但是您还有其他错误,我稍后会检查它们

注意:除非您想使用特定的回调值,否则不应将回调与 jsonp 一起使用,另一方面 json 使用回调值(自动生成),如果您想回调一个函数,请将其放在完成或成功回调函数中阿贾克斯的

于 2013-06-14T03:54:09.487 回答
0

jsonp数据类型仅支持 json 格式的数据。

在您的情况下,http://www.netflix.com不支持 jsonp 输出类型,它会将 html 内容作为响应发回,所以我认为不可能jsonp与给定资源一起使用

于 2013-06-14T03:02:08.200 回答