私が現在開発しているコードのアイデアは、(サーバーから取得した) JSON ファイルからデータを抽出し、美しく素敵なグラフィックを使用して結果を表示することです。問題は、JSON の結果を Jquery コードに保存するオブジェクトを取得できないため、それらをグラフィックにロードできることです。簡単にするために、私のコードは次のようになります (Javascript 部分)
var obj; //I initialize it here in order to make it global though it doesn't work
function handle_json() {
if (http_request.readyState == 4) {
if (http_request.status == 200) {
var json_data = http_request.responseText;
obj = eval("(" + json_data + ")");
//at this point I have the information I want in "obj"
} else {
alert("A problem ocurred.");
}
http_request = null;
} }
しかし、情報にアクセスして表示できるように、「obj」を jQuery コードに送信したいと考えています。しかし、これを試してみると(jQuery部分)
$(function () {
alert(obj.results.bindings[0].a.value); //<-- this doesn't work, obj isn't initialized
var fert = [];
fert = [[1990, 1.28], [1995, 1.25], [2000, 1], [2005, 1.3], [2010, 1.83]];
var plot = $.plot($("#placeholder"),
[ { data: fert, label: "Fertility"} ], {
series: {
lines: { show: true },
points: { show: true }
},
grid: { hoverable: true, clickable: true },
yaxis: { min: 0, max: 2}
});
問題が何であるかがわかります。非同期の Ajax 呼び出しを行ったので、json 情報 ( obj = eval("(" + json_data + ")") ) を評価した直後に jQuery を実行する必要がありますが、そうではありませんノーハウ!それが役立つ場合は、「flot」というライブラリを使用してグラフィックを作成しました。どうもありがとう!どんな助けでも感謝します:)