getJson и анализируем для создания списка (пока) jQuery / Yahoo Finance API - PullRequest
0 голосов
/ 08 декабря 2011

У меня почти все работает, но я не могу решить проблему с разбором.Если кто-то может помочь, я был бы очень благодарен!

Я пытаюсь запросить Yahoo Finance API и проанализировать результаты, используя jQuery.Вот мой код для этого:

  <script>
$(document).ready(function(){

var url = "http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.quotes%20WHERE%20symbol%3D'NPO'&format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys&callback";

$.getJSON(url + "&format=json&jsoncallback=?", function(data) {
  var items = [];

  $.each(data, function(key, val) {
    items.push('<li id="' + key + '">' + val + '</li>');
  });

  $('<ul/>', {
    'class': 'my-new-list',
    html: items.join('')
  }).appendTo('body');
});


});
</script>

Но я получаю эту ошибку: enter image description here

Любая помощь по преодолению этой ошибки будет принята с благодарностью.

Спасибо!

Ответы [ 3 ]

3 голосов
/ 08 декабря 2011
  • jsoncallback параметр не используется службой.
  • Вам даже не нужно указывать параметр callback.Он добавляется параметром getJSON()
  • format, который уже указан в url
  • В вашем массиве items хранятся объекты, так как данные находятся под data.query.results.quote

Попробуйте:

var url = "http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.quotes%20WHERE%20symbol%3D'NPO'&format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys";

$.getJSON(url, function(data) {
  var items = [];
  $.each(data.query.results.quote, function(key, val) {
    items.push('<li id="' + key + '">' + val + '</li>');
  });
  $('<ul/>', { 'class': 'my-new-list', html: items.join('')}).appendTo('body');
});

Рабочий код: ЗДЕСЬ .

3 голосов
/ 08 декабря 2011

YQL использует параметр callback=?, а не jsoncallback=?, попробуйте это:

var url = "http://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20yahoo.finance.quotes%20WHERE%20symbol%3D'NPO'&format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys";

$.getJSON(url + "&format=json&callback=?", function(data) {

Редактировать: Обратите внимание, URL-адрес тоже должен был измениться.

1 голос
/ 08 декабря 2011

отлично работает у меня при удалении &jsoncallback=?.

$(document).ready(function() {

    var url = "http://query.yahooapis.com/v1/public/yql?" +                    
              "q=select%20*%20from%20yahoo.finance.quotes%20WHERE%20symbol%3D'NPO'" + 
              "&format=json&diagnostics=true" + 
              "&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys";

    $.getJSON(url, function(data) {

        console.log( data );

    });
});

У вас уже есть format=json в основной строке.

JSFIDDLE DEMO

...