我的目的是使用Google应用脚本制作一个小型的测验脚本。问题和可能答案的数据位于Google电子表格中。电子表格中的范围由脚本调用,并用作2d数组。大多数情况下脚本运行正常,但有时候
'typeerror无法读取未定义'
的属性'0'
似乎随机弹出。
我可能使用错误的数组功能,但我无法理解它。
1在大多数关于数组的例子中,使用for循环。由于我的数组中的数据不会改变,使用这个for循环仍然是强制性的吗?
2将电子表格数据存储到缓存中是否有益?
function drawQuestion (){
var app = UiApp.getActiveApplication();
var cache = CacheService.getPrivateCache();
//Add Spreadsheet DB
var sheet = SpreadsheetApp.openById(SPREADSHEET_ID);
var data = sheet.getDataRange().getValues();
var min =1;
var max = MAX;
var xnumber = (Math.floor(Math.random() * (max - min + 1)) + min);
//for (var i = 0; i < data.length; i++) {
var question1 = String(data[xnumber][0]); //when I change this '0' in a '1' it gives me a typeerror cannot read property 1 - message.
var answer1 = String(data[xnumber][1]);
var answer2 = String(data[xnumber][2]);
var answer3 = String(data[xnumber][3]);
var answer4 = String(data[xnumber][4]);
var correct1 = Number(data[xnumber][5]);
// var background1 = data[xnumber][6];
// var explanation1 = data[xnumber][7];
// }
//Write the new Question
var statusLabel = app.getElementById("statusLabel");
statusLabel.setText(question1);
//Answer1
var button1 = app.getElementById("button1");
button1.setText(answer1);
//Answer2
var button2 = app.getElementById("button2");
button2.setText(answer2);
//Answer3
var button3 = app.getElementById("button3");
button3.setText(answer3);
//Answer4
var button4 = app.getElementById("button4");
button4.setText(answer4);
//Store correct answer & explanation in cache
cache.put('correct1', Number(correct1));
//cache.put('explanation1', explanation1);
}
答案 0 :(得分:0)
它表示在该实例期间未定义data[xnumber]
。您正在访问未定义对象的索引0
。在使用data[xnumber][0]
之前,验证data[xnumber]
和data[xnumber][0]
有效。
同样在您的代码中,请验证您xnumber
的价值。
通过使用此表达式,您的xnumber
可以具有任何价值(不保证介于0
和max
之间)
var xnumber = (Math.floor(Math.random() * (max - min + 1)) + min);
在循环中使用数组也没有限制。但它可以通过为循环提供适当的验证条件来防止这类错误