我对这一切还很陌生,但我希望直接使用 Google 电子表格中的名称填充 Apps 脚本 Web 应用程序 HTML 下拉表单条目。到目前为止,我已经能够从电子表格的 A 列返回一组名称。此外,JS 的“填充表单”部分成功填充了 HTML 表单。
我的问题是如何连接两者?我尝试用函数 getColleagueList() 替换 JS 后半部分中的硬编码数组,并删除该函数,只留下变量,但表单仍然没有填充。我觉得这是一个简单的解决方案,但不知道该怎么做。提前致谢。
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<select id="selectColleague">
<option disabled selected value="">
Reviewer's Name
</option>
</select>
<script type="text/javascript">
//Gets Names
function getColleagueList() {
var s1 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Roster Import');
var range = s1.getRange(2, 1,s1.getLastRow()-1, 1).getValues();
return range;
}
//Populates Form
var select = document.getElementById("selectColleague");
var options = ["1", "2", "3", "4", "5"];
for(var i = 0; i < options.length; i++) {
var opt = options[i];
var el = document.createElement("option");
el.textContent = opt;
el.value = opt;
select.appendChild(el);
}
</script>
getColleagueList() 应该是服务器端函数。您可以将其放入 Code.gs 文件中。然后从 JavaScript 调用服务器端函数,如下所示:
您可以在这里了解更多信息:https://developers.google.com/apps-script/guides/html/communication
<script>
function onSuccess(values) {
var select = document.getElementById("selectColleague");
var options = values[0]; //Two dimensional array
for(var i = 0; i < options.length; i++) {
var opt = options[i];
var el = document.createElement("option");
el.textContent = opt;
el.value = opt;
select.appendChild(el);
}
}
google.script.run.withSuccessHandler(onSuccess)
.getColleagueList();
</script>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)