我正在写一个小的谷歌应用程序脚本,它允许从开发人员列表中选择几个名称。但在我的doPost(E)的方法,我不能访问张贴值的数组(它undefinded),事件如果我检查所有复选框...无法访问事件发布值
function onOpen() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
// add the new menu
var menuEntries = [];
menuEntries.push({name: "Edit page", functionName: "start"})
ss.addMenu("My tools", menuEntries);
}
function start() {
var app = UiApp.createApplication();
app.setTitle("Edit page");
var formPanel = app.createFormPanel();
var mainPanel = app.createVerticalPanel();
var gridPanel = app.createGrid(1, 2);
// developpers
var developperPanel = app.createVerticalPanel()
var developpers = [];
developpers.push("John", "Peter", "Max", "Johnny");
for (var i = 1; i < developpers.length; ++i) {
var checkbox = app.createCheckBox(developpers[i]).setName("dev"+i);
developperPanel.add(checkbox);
}
gridPanel.setWidget(0,0,app.createLabel("Developpers : "));
gridPanel.setWidget(0,1,developperPanel);
// submit button
mainPanel.add(gridPanel);
mainPanel.add(app.createSubmitButton().setText("OK"));
formPanel.add(mainPanel);
app.add(formPanel);
var ss = SpreadsheetApp.getActive();
ss.show(app);
}
function doPost(e) {
var app = UiApp.getActiveApplication();
app.add(app.createLabel(e.values[0])); // Here is the error.
return app;
}
在为例,该列表是固定但在我的真实脚本中,我使用电子表格创建了列表。
感谢
最大
你有没有试图命名你的启动函数'doGet'?我认为这是强制性的... – 2012-07-12 09:42:48
是的,我试过了,但没有奏效。但是,如果我打电话给'e.parameter.dev1',我可以访问发送的值。 – Max 2012-07-12 09:48:40
对不起,我想我不明白你想要做什么......你可以发布你的'doPost(e)'函数吗? – 2012-07-12 10:07:16