【发布时间】:2015-08-20 04:32:33
【问题描述】:
我想使用 html 服务 google apps 脚本创建一个交互式网络应用程序。
我无法将带有函数的onclick 事件添加到按钮中。
这些函数在第一次加载网页时执行,但在点击时不执行。如果我稍后单击该按钮,则不会发生任何事情。
Here is the link for my project
代码.gs:
function doGet() {
var template = HtmlService.createTemplateFromFile('Index');
return template.evaluate()
.setTitle('Web App Window Title')
.setSandboxMode(HtmlService.SandboxMode.NATIVE);
}
function getmenus() {
var folder = DriveApp.getFolderById('0B5vEst6Tvg8nfmhRU1h4V044ODJlX2VxeHdKeFFicUx0UlMzMWhZcUxjTkRHSlZiR3FlT1k');
var datax = []
var result = [[]];
var filess = folder.getFilesByType(MimeType.GOOGLE_SHEETS);
while (filess.hasNext()) {
datax.push(filess.next());
}
datax.sort(function sorting(x,y){
var xp = x.getName().toLowerCase();
var yp = y.getName().toLowerCase();
return xp == yp ? 0 : xp < yp ? -1 : 1;
});
for (var a in datax) {
var ss = SpreadsheetApp.openById(datax[a].getId());
var info = ss.getSheetByName('Info');
var url = info.getRange('B1').getValue();
result[a] = [datax[a].getName(),datax[a].getId(),url];
}
return result;
}
function processmenu(result) {
var ss = SpreadsheetApp.openById(result);
var sheet = ss.getActiveSheet();
var range = sheet.getDataRange();
var values = range.getValues();
return values;
}
JavaScript.html:
<script>
google.script.run.withSuccessHandler(loadmenu).getmenus();
function loadmenu(result) {
var mainmenu = document.getElementById('menunav');
mainmenu.innerHTML='';
for (var a in result) {
var form = document.createElement('form');
var hidden = document.createElement('input');
hidden.type='hidden';
hidden.name='name';
hidden.value=result[a][1];
var button = document.createElement('input');
button.type='button';
button.name='menu';
button.value=result[a][0];
button.onclick=menuclick(result[a][1]);
form.appendChild(hidden);
form.appendChild(button);
mainmenu.appendChild(form);
var br = document.createElement("br");
mainmenu.appendChild(br);
}
}
function menuclick(result) {
google.script.run.withSuccessHandler(updateoptions).processmenu(result);
}
function updateoptions(values) {
alert(values);
}
</script>
请帮助我解决问题,也许如何以更好的方式重写代码。
谢谢
【问题讨论】:
-
您是否已将触发器添加到您的函数中?您需要将事件链接到触发器,以便事件执行方法。
-
你知道如何在这个函数上添加“onclick”触发器吗?我认为它已经在这一行完成了:button.onclick=menuclick(result[a][1]);
-
我更新了您的 Apps 脚本代码。感谢您提供对文件的访问权限。这使得找到问题成为可能。
标签: javascript html dom google-apps-script