0

以下は、getJSON メソッドが機能しない私のコードです。

 function loadJson() {
        $(document).ready(function () {
            alert("inside");
            var chart;
            var url = "values.json";
            var seriesData = [];
            var xCategories = [];
            var i, cat;
            alert("outside");
            $.getJSON(url, function (data) {
                alert("inside JSON function");
for (i = 0; i < data.length; i++) {
                    cat = '' + data[i].period_name;
                    if (xCategories.indexOf(cat) === -1) {
                        xCategories[xCategories.length] = cat;
                    }
                }
                for (i = 0; i < data.length; i++) {
                    if (seriesData) {
                        var currSeries = seriesData.filter(function (seriesObject) {
                            return seriesObject.name == data[i].series_name;
                        }
                        );
                        if (currSeries.length === 0) {
                            seriesData[seriesData.length] = currSeries = { name: data[i].series_name, data: [] };
                        } else {
                            currSeries = currSeries[0];
                        }
                        var index = currSeries.data.length;
                        currSeries.data[index] = data[i].period_final_value;
                    }
                    else {
                        seriesData[0] = { name: data[i].series_name, data: [data[i].period_final_value] }
                    }
                }

                //var chart;
                //$(document).ready(function() {
                chart = new Highcharts.Chart({
                    chart: {
                        renderTo: 'container',
                        type: 'bar'
                    },
                    title: {
                        text: 'Stacked column chart'
                    },
                    xAxis: {
                        categories: xCategories
                    },
                    yAxis: {
                        //min: 0,
                        //max: 100,
                        title: {
                            text: 'Total fruit consumption'
                        },
                        stackLabels: {
                            enabled: false,
                            style: {
                                fontWeight: 'bold',
                                color: (Highcharts.theme && Highcharts.theme.textColor) || 'gray'
                            }
                        }
                    },
                    legend: {
                        align: 'right',
                        x: -100,
                        verticalAlign: 'top',
                        y: 20,
                        floating: true,
                        backgroundColor: (Highcharts.theme && Highcharts.theme.legendBackgroundColorSolid) || 'white',
                        borderColor: '#CCC',
                        borderWidth: 1,
                        shadow: false
                    },
                    tooltip: {
                        formatter: function () {
                            return '<b>' + this.x + '</b><br/>' +
                                this.series.name + ': ' + this.y + '<br/>'
                        }
                    },

                    series: seriesData


                });
            });

        });
    }

url では、次のように values.json が私の JSON ファイルです。

[{"series_name":"Actual","period_name":"Q1 / 2013","period_final_value":17},
 {"series_name":"Actual","period_name":"Q2 / 2013","period_final_value":15},
 {"series_name":"Actual","period_name":"Q3 / 2013","period_final_value":13},
 {"series_name":"Actual","period_name":"Q4 / 2013","period_final_value":19},

 {"series_name":"Alarm","period_name":"Q1 / 2013","period_final_value":14.103},
 {"series_name":"Alarm","period_name":"Q2 / 2013","period_final_value":14.404499999999999},
 {"series_name":"Alarm","period_name":"Q3 / 2013","period_final_value":14.966999999999999},
 {"series_name":"Alarm","period_name":"Q4 / 2013","period_final_value":50},

 {"series_name":"Target","period_name":"Q1 / 2013","period_final_value":15.67},
 {"series_name":"Target","period_name":"Q2 / 2013","period_final_value":16.005},
 {"series_name":"Target","period_name":"Q3 / 2013","period_final_value":16.63},
 {"series_name":"Target","period_name":"Q4 / 2013","period_final_value":100}]

ファイルはレンダリングされますが、データはグラフに表示されません。 ASP.NET Web アプリケーションの VS にあり、次のように javascript で body onLoad の loadJson 関数を呼び出しました。

<body onload="loadJson();">

しかし、メソッドは実行されず、これを解決できません。どんな助けも大歓迎です...

- - - - - 余分な仕事 - - -

getJSON メソッドの上の任意の変数に JSON データを追加し、getJSON メソッドとアクセスを削除すると、グラフは適切に取得されますが、getJSON メソッドを使用している場合は機能しません。

-----エラー検査済み----------

chrome でエラーを調べたところ、json ファイルを取得できないことがわかりました。JSON ファイルをプロジェクト フォルダーに保存しました。次に、json ファイルを localhost に保存してみましたが、それでも同じエラーが表示されます。

今、私は aspx ページでの MIME タイプの処理で問題に直面していると考えています..それとリンクするものはありますか..??

4

4 に答える 4

2

1) 有効な json を使用していることを確認してください: www.jsonlint.com

2) json ファイルを localhost で実行します。ブラウザの json ファイルが localhost で実行されているかどうか教えてください。これがweb.configにあることを確認してください

  <system.webServer>
    <staticContent>
      <mimeMap fileExtension=".json" mimeType="application/json" />
    </staticContent>
  </system.webServer>

getJSON3)関数を使用したアラート情報

$(document).ready(function () {
    $.getJSON("values.json", function (data) {
        $.each(data, function () {
            alert(this.series_name);
        });
    });
});

4) これらのテストに合格したら、jQuery コードの作成を続けます。

于 2013-11-14T15:06:22.680 に答える
0

http://jsonlint.com/で JSON に問題が見つかりました

[{"series_name":"Actual","period_name":"Q1 / 2013","period_final_value":17},
 {"series_name":"Actual","period_name":"Q2 / 2013","period_final_value":15},
 {"series_name":"Actual","period_name":"Q3 / 2013","period_final_value":13},
 {"series_name":"Actual","period_name":"Q4 / 2013","period_final_value":19},]

ブラケットの,直前のため、有効な JSON ではありません。]

于 2013-11-14T11:27:04.637 に答える