回答編集履歴

1

コードの追記

2015/08/07 03:19

投稿

flat
flat

スコア617

test CHANGED
@@ -3,3 +3,105 @@
3
3
  [ajaxでjsonを取得しグローバル変数へ格納(javascript ajax jquery) | nktmemo](https://nktmemo.wordpress.com/2014/01/07/ajaxでjsonを取得しグローバル変数へ格納(javascript-ajax-jquery)/)
4
4
 
5
5
  [JavascriptでAJAXで取得した値を変数にキャッシュして使う - 何度やっても同じ](http://xfan.hateblo.jp/entry/20110311/1299852204)
6
+
7
+
8
+
9
+ **追記**
10
+
11
+ 前述したリンク先にもある通り、setTimeout関数を利用して変数に値が入ったタイミングで実行という処理が出来る様です。
12
+
13
+ ```JavaScript
14
+
15
+ // データを格納するための変数を宣言
16
+
17
+ var json_data;
18
+
19
+ $.ajax({
20
+
21
+ type: 'GET',
22
+
23
+ url: 'json',
24
+
25
+ dataType: 'json',
26
+
27
+ cache: false,
28
+
29
+ success: function( data ) {
30
+
31
+ var sheetsEntry = data.feed.entry;
32
+
33
+ json_data = sheetsEntry[0].gs$cell.$t;
34
+
35
+ }
36
+
37
+ });
38
+
39
+
40
+
41
+ setTimeout( function() {
42
+
43
+ // 変数 json_data の値がnullではない時
44
+
45
+ if( json_data != null ){
46
+
47
+ // この中で変数 json_data を用いた処理を行う
48
+
49
+ console.log( json_data ); // JSONのデータを取得出来る
50
+
51
+ } else { // 変数 json_data の値がnullの時
52
+
53
+ // 100ms後に自身(無名関数)を再実行
54
+
55
+ setTimeout( arguments.callee, 100 );
56
+
57
+ }
58
+
59
+ });
60
+
61
+
62
+
63
+ console.log( json_data ); // undefined
64
+
65
+ ```
66
+
67
+ また、コメントでeripongさんが仰っていますが、jQuery.ajaxの非同期オプションを無効にして同期リクエストを有効にする事でも取得出来ます。
68
+
69
+ そして、同じくeripongさんが仰っていますが、同期リクエストはその処理が完了するまでブラウザをロックしてしまい、ロックしている間は操作を一切受け付けなくなるのでお勧め出来ません。
70
+
71
+ ```JavaScript
72
+
73
+ // データを格納するための変数を宣言
74
+
75
+ var json_data;
76
+
77
+ $.ajax({
78
+
79
+ type: 'GET',
80
+
81
+ url: 'json',
82
+
83
+ dataType: 'json',
84
+
85
+ cache: false,
86
+
87
+ async: false, // 非同期オプションを無効にして同期リクエストを行う *1
88
+
89
+ success: function( data ) {
90
+
91
+ var sheetsEntry = data.feed.entry;
92
+
93
+ json_data = sheetsEntry[0].gs$cell.$t;
94
+
95
+ }
96
+
97
+ // *1 同期リクエストは処理が終わるまでブラウザをロックしてしまいます。
98
+
99
+ });
100
+
101
+
102
+
103
+ console.log( json_data ); // JSONのデータを取得出来る
104
+
105
+ ```
106
+
107
+