在三个jquery json请求中,其中一个提出了跨域错误,因为我不知道如何包含回调=? (或者为什么这表示json vs jsonp)。
对同一个api的两个请求,只有一个使用参数,这对我来说是新的,为什么它不起作用(我已经尝试添加& callback =?和其他此类解决方案。)
谢谢!
var names = ["athenelive", "riotgames", "aphromoo"];
var obj = jQuery.parseJSON('{"name": {"life": "{life}","logo": "{logo}","status": "{status}","preview": "{preview}","url": "{url}"}}');
wtfJSON();
function wtfJSON() {
for (index = 0; index < names.length; ++index) {
$.getJSON("https://api.twitch.tv/kraken/channels/" + names[index] + "/?callback=?", function (json) {
$('body').append("Stufffff: " + obj.name.logo + "<br>");
$('body').append("Name: " + json.name + "<br>");
$('body').append("Logo: " + json.logo + "<br>");
$('body').append("Status(title): " + json.status + "<br>");
$('body').append("URL: " + json.url + "<br>");
});
$.getJSON("https://api.twitch.tv/kraken/streams/" + names[index] + "/?callback=?", function (json) {
if (json.stream !== null) {
$('body').append("Preview: " + json.stream.preview.medium + "<br>");
}
});
$.getJSON("https://api.twitch.tv/kraken/channels/" + names[index] + "/videos?limit=3&broadcasts=true$callback=?", function (json) {
$('body').append("Video Name: " + json + "<br>");
});
}
}
答案 0 :(得分:0)
看看你的控制台:
XMLHttpRequest无法加载https://api.twitch.tv/kraken/channels/athenelive/videos?limit=3&broadcasts=true。 Access-Control-Allow-Origin不允许原点http://fiddle.jshell.net。
将$.getJSON
与callback
参数一起使用实际上会发送一个JSONP请求,jQuery只需创建一个<script>
标记并使用唯一的全局回调即可实现。如果没有它,您会尝试向其他网站发送常规AJAX请求,这是您的浏览器所不允许的。
添加callback
参数,它将起作用:
$.getJSON("https://api.twitch.tv/kraken/channels/" + names[index] + "/videos?limit=3&broadcasts=true&callback=?", function (json) {