0

我的目的是使用 Google Apps 脚本制作一个小测验脚本。问题和可能答案的数据位于 Google 电子表格中。电子表格中的范围由脚本调用并用作二维数组。大多数时候脚本运行良好,但有时

'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);

  } 
4

1 回答 1

0

它说你data[xnumber]在那个实例中没有定义。您正在访问未定义对象的索引0。在使用之前data[xnumber][0]验证data[xnumber]并且data[xnumber][0]是有效的。

同样在您的代码中,请验证您的xnumber.

通过使用这个表达式,你xnumber可以有任何值(不保证在0and之间max

var xnumber = (Math.floor(Math.random() * (max - min + 1)) + min);

在循环内使用数组也没有限制。但它将通过为循环提供适当的验证条件来防止这些类型的错误

于 2013-03-12T06:20:35.013 回答