0

私はほとんど機能していますが、解析の問題を乗り越えることができません。誰かが助けることができれば、私はとても感謝しています!

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>

しかし、私はこのエラーが発生しています: ここに画像の説明を入力

このエラーを克服するための助けをいただければ幸いです。

ありがとう!

4

3 に答える 3

3

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も変更する必要があることに注意してください。

于 2011-12-08T15:42:48.430 に答える
3
  • 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');
});

作業コードはHEREです。

于 2011-12-08T16:01:52.043 に答える
1

を削除すると、うまく機能します&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 デモ

于 2011-12-08T15:51:38.343 に答える