javascript - 无法完成 .getJSON 请求?

标签 javascript jquery html json getjson

首先,这是我要完成的跨域请求。这是我用作引用的 Strava API 白皮书的链接。 Strava Wiki

请查看我在下面使用的代码。如果无法使用 jQuery 执行请求,您能否给我一个其他方法的示例? (例如 AJAX)我已经完成了研究,但我承认我的知识还不足以理解为什么请求不起作用。我是否需要在显示警报之前插入一个等待响应的参数,或者这是隐含的?提前致谢!

 <html lang="en">
 <head>
   <meta charset="utf-8">
   <title>jQuery demo</title>
 </head>
 <body>
   <a href="http://jquery.com/">jQuery</a>
   <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
   <script>
        $(document).ready(function(){
            $("a").click(function(event){
                $.getJSON('http://www.strava.com/api/v1/segments/637215', function(data) {
                    alert(data);
                });
            });
         });
   </script>
 </body>
 </html>

最佳答案

有关您的解决方案为何无法按预期工作的更多信息,请参阅:Access-Control-Allow-Origin Multiple Origin Domains?

尝试使用 .ajax 方法代替 dataType: "jsonp":

$.ajax({
   url: "http://www.strava.com/api/v1/segments/637215",
    dataType: 'jsonp',
    success: function(data){
        console.log(data);
     }
 });

运行它会得到以下结果:

{"segment":{"id":637215,"name":"Highway 33 Climb - Matilija Lake to Rose Valley","distance":16779.2,"elevationGain":1101.1,"elevationHigh":1070.9,"elevationLow":289.54,"averageGrade":4.64087,"climbCategory":"1"}}

EXAMPLE

请注意,返回的数据似乎确实有错误,但我能够看到它。 (请在下面查看 Musa 的评论)。

编辑

或者你可以改变:

$.getJSON('http://www.strava.com/api/v1/segments/637215', function(data) {
                    console.log(data);
                });

到:

$.getJSON('http://www.strava.com/api/v1/segments/637215?callback=?', function(data) {
                    console.log(data);
                });

这将导致 .getJSON() 改用 jsonp

如果 URL 包含字符串“callback=?” (或类似的,由服务器端 API 定义),请求被视为 JSONP。

EXAMPLE

关于javascript - 无法完成 .getJSON 请求?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12430198/

相关文章:

javascript - 将图像放在 div 上,并随图像调整大小

javascript - 我应该通过 id/class 名称还是数据属性来选择 DOM 元素?

javascript - 两个相同的功能以不同的方式工作

javascript - Node webkit : Cut/copy/paste right click context menu and iframe

javascript - 将链接添加到 DfP HTML5 横幅的正确方法是什么?

JavaScript 变量语法 : Unexpected identifier

javascript - 在动态添加的行中突出显示所选字段会使它们消失

javascript - 将字符串传递给函数但需要一个数组

javascript - 使用命令关闭窗口并重新加载父页面后,如何使重新加载后自动弹出一个div?

javascript - PHP var (051) 在 Javascript 中获取值 41?