Google应用脚本列表框事件处理,未定义的值

时间:2012-10-18 21:05:15

标签: event-handling listbox google-apps-script

此应用程序脚本的想法是根据列表框LbxJobTypes中的选定项填充列表框LbxJobs。

我为e.parameter.LbxJobType获取了一个未定义的值,这似乎阻止了LbxJobs的条件填充。

我通过硬编码(我设置JobType = T300_JOB_TYPE)JobTypeValueHandler函数成功测试了处理程序(JobTypeValueHandler),并按预期填充了LbxJobs列表框。

检查e.parameter.source时,我得到“LbxJobType”。列表框是在GUI构建器中创建的。

var T200_JOB_TYPE = 1;
var T300_JOB_TYPE = 2;

function doGet() {
  var app = UiApp.createApplication();

  app.add(app.loadComponent("BasicCalculator"));
  var Dischandler = app.createServerHandler('DiscClickHandler');
  app.getElementById('chbxDiscl').addValueChangeHandler(Dischandler);    
  return app;
 }


function DiscClickHandler(e) {
  var app = UiApp.getActiveApplication();   
  var Discpanel = app.getElementById('FLpnlDisc');

  BCalcSetup(app);
  Discpanel.setVisible(false);  
  return app;
}


function BasicClickHandler(e) {
  var app = UiApp.getActiveApplication();

  return app;
}


function BCalcSetup(app){
  var BCalcpanel = app.getElementById('APnlBCalc');  
  var lbxJobType = app.getElementById('LbxJobType'); 
  var JobTpyehandler = app.createServerChangeHandler('JobTypeValueHandler'); 
  var lbxJobs = app.getElementById('LbxJobs'); 

  JobTpyehandler.addCallbackElement(lbxJobType);
  lbxJobType.addChangeHandler(JobTpyehandler);
  lbxJobType.addItem('Title 200');
  lbxJobType.addItem('Title 300');
  loadClassifications(lbxJobs,T200_JOB_TYPE);
  BCalcpanel.setVisible(true);  
}


function JobTypeValueHandler(e) {
  var app = UiApp.getActiveApplication();  
  var JobType=T200_JOB_TYPE;
  var lboxJobs=app.getElementById('LbxJobs');  

  if (e.parameter.LbxJobType=='Title 300'){JobType=T300_JOB_TYPE;}
  loadClassifications(lboxJobs,JobType);
  app.close();
  return app;
}


function loadClassifications(lbox,JobType){ 
  var spreadsheet = SpreadsheetApp.openById(SPREADSHEET_ID);

  lbox.clear();
  if (JobType==T300_JOB_TYPE){
    var T3data =spreadsheet.getRangeByName('Title300Jobs').getValues();  
    for (var row1 = 1; row1 < T3data.length; row1++) {
      lbox.addItem(T3data[row1]);
    }
  }else{   
    var T2data =spreadsheet.getRangeByName('Title200Jobs').getValues();  
    for (var row2 = 1; row2 < T2data.length; row2++) {
      lbox.addItem(T2data[row2]);  
    }
  } 
}

1 个答案:

答案 0 :(得分:0)

我觉得有点傻但我想出来了。我遇到的问题是当我在GUI构建器中创建接口时,我没有填写这些列表框的Name属性。我回到GUI构建器并填写每个框的名称属性,现在它就像一个冠军。生活和学习