var questions = [];
$(document).ready(function() {
$.ajax({
type:"GET",
url:"question.xml",
dataType: "xml",
success: function(data) {
$(data).find('item').each(function() {
var question = $(this).find('question').text();
var answer = $(this).find('qid').text();
var opt1 = $(this).find('ans1').text();
var opt2 = $(this).find('ans2').text();
var opt3 = $(this).find('ans3').text();
var opt4 = $(this).find('ans4').text();
questions.push({'question':question, 'answer':answer, 'opt1':opt1, 'opt2':opt2, 'opt3':opt3, 'opt4':opt4});
});
alert(questions.length); // here it shows length as 20
}
});
alert(questions.length); // here it shows length as 0 });
グローバル (質問) として宣言された配列があります。問題は、ajax 成功の内部で配列にアクセスすると 20 個の要素があるのに、アクセスしようとすると配列の長さが 0 になることです。
誰かが私が間違っていることを説明できますか。