Google应用脚本/ javascript 2D数组类型错误

时间:2013-03-12 06:03:34

标签: javascript arrays google-apps-script

我的目的是使用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);

  } 

1 个答案:

答案 0 :(得分:0)

它表示在该实例期间未定义data[xnumber]。您正在访问未定义对象的索引0。在使用data[xnumber][0]之前,验证data[xnumber]data[xnumber][0]有效。

同样在您的代码中,请验证您xnumber的价值。

通过使用此表达式,您的xnumber可以具有任何价值(不保证介于0max之间)

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

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