google-apps-script - 使用脚本将 HTML 表格数据发送回 Google 表格
问题描述
我正在使用这个网站的一个例子
我正在尝试将 HTML 表中的值添加到活动电子表格的 a1 单元格中。runsies(values)
我有一种感觉,甚至没有调用该函数。
问题是,我在日志中什么也没有。理想的解决方案将是用户选择分离单元的结果。例如:A1、A2 等中的橙色 1、蓝色 2 等
我做错了什么?
代码.js
//--GLOBALS--
var ui = SpreadsheetApp.getUi();
function onOpen(e){
// Create menu options
ui.createAddonMenu()
.addSubMenu(ui.createMenu("Admin")
.addItem("Test","test"))
.addToUi();
};
function test(){
//Call the HTML file and set the width and height
var html = HtmlService.createHtmlOutputFromFile("testUI")
.setWidth(450)
.setHeight(300);
//Display the dialog
var dialog = ui.showModalDialog(html, "Select the relevant module and unit");
};
//--GLOBALS--
var ui = SpreadsheetApp.getUi();
function onOpen(e){
// Create menu options
ui.createAddonMenu()
.addSubMenu(ui.createMenu("Admin")
.addItem("Test","test"))
.addToUi();
};
function test(){
//Call the HTML file and set the width and height
var html = HtmlService.createHtmlOutputFromFile("testUI")
.setWidth(450)
.setHeight(300);
//Display the dialog
var dialog = ui.showModalDialog(html, "Select the relevant module and unit");
};
function runsies(values){
//Display the values submitted from the dialog box in the Logger and in the A1 cell of active sheet.
var sheet = SpreadsheetApp.getActiveSheet();
sheet.getRange(1,1).setValue([values])
Logger.log(values);
};
HTML
<html>
<head>
<base target="_top">
<link rel="stylesheet" href="https://ssl.gstatic.com/docs/script/css/add-ons1.css">
</head>
<body>
<div>
<table>
<col width="60">
<col width="50">
<col width="50">
<col width="50">
<col width="50">
<col width="50">
<col width="50">
<col width="50">
<col width="50">
<col width="50">
<tr>
<th></th><th><strong>Unit:</strong></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th><th></th>
</tr>
<tr>
<th><strong>Module</strong></th>
<th><strong>n/a</strong></th>
<th><strong>1</strong></th>
<th><strong>2</strong></th>
<th><strong>3</strong></th>
<th><strong>4</strong></th>
<th><strong>5</strong></th>
<th><strong>6</strong></th>
<th><strong>7</strong></th>
<th><strong>8</strong></th>
</tr>
<tr>
<td>Orange </td>
<td><input type="radio" name="orange" value="na" checked></td>
<td><input type="radio" name="orange" value="1"></td>
<td><input type="radio" name="orange" value="2"></td>
<td><input type="radio" name="orange" value="3"></td>
<td><input type="radio" name="orange" value="4"></td>
<td><input type="radio" name="orange" value="5"></td>
<td><input type="radio" name="orange" value="6"></td>
<td><input type="radio" name="orange" value="7"></td>
<td><input type="radio" name="orange" value="8"></td>
</tr>
<tr>
<td>Blue </td>
<td><input type="radio" name="blue" value="na" checked></td>
<td><input type="radio" name="blue" value="1"></td>
<td><input type="radio" name="blue" value="2"></td>
<td><input type="radio" name="blue" value="3"></td>
<td><input type="radio" name="blue" value="4"></td>
<td><input type="radio" name="blue" value="5"></td>
<td><input type="radio" name="blue" value="6"></td>
<td><input type="radio" name="blue" value="7"></td>
<td><input type="radio" name="blue" value="8"></td>
</tr>
<tr>
<td>Green </td>
<td><input type="radio" name="green" value="na" checked></td>
<td><input type="radio" name="green" value="1"></td>
<td><input type="radio" name="green" value="2"></td>
<td><input type="radio" name="green" value="3"></td>
<td><input type="radio" name="green" value="4"></td>
<td><input type="radio" name="green" value="5"></td>
<td><input type="radio" name="green" value="6"></td>
<td><input type="radio" name="green" value="7"></td>
<td><input type="radio" name="green" value="8"></td>
</tr>
<tr>
<td>Purple </td>
<td><input type="radio" name="purple" value="na" checked></td>
<td><input type="radio" name="purple" value="1"></td>
<td><input type="radio" name="purple" value="2"></td>
<td><input type="radio" name="purple" value="3"></td>
<td><input type="radio" name="purple" value="4"></td>
<td><input type="radio" name="purple" value="5"></td>
<td><input type="radio" name="purple" value="6"></td>
<td><input type="radio" name="purple" value="7"></td>
<td><input type="radio" name="purple" value="8"></td>
</tr>
</table>
<input type="submit" value="Submit" class="action" onclick="form_data()" >
<input type="button" value="Close" onclick="google.script.host.close()" />
</div>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js">
</script>
<script>
function form_data(){
var values = [{
"orange":$("input[name=orange]:checked").val(),
"blue":$("input[name=blue]:checked").val(),
"green":$("input[name=green]:checked").val(),
"purple":$("input[name=purple]:checked").val()
}];
google.script.run.withSuccessHandler(closeIt()).runsies(values);
closeIt()
};
function closeIt(){
google.script.host.close()
};
</script>
</body>
</html>
==================================================== =====
更新
基于@Cooper 的回答。我把这个改成google.script.run.withSuccessHandler(closeIt()).runsies(values);
这个 google.script.run.withSuccessHandler(closeIt).runsies(values);
这有帮助,现在我进入{orange=1, purple=1, blue=1, green=1}
A1
用那个代码sheet.getRange(1,1).setValue([values])
如何在不同的单元格中分离这些数据?
例如:在单元格 A1 中得到 1 不是{orange=1, purple=1, blue=1, green=1}
我想,我有这个代码的字典类型数据(在python中它是这样称呼的)。
var values = {
"orange":$("input[name=orange]:checked").val(),
"blue":$("input[name=blue]:checked").val(),
"green":$("input[name=green]:checked").val(),
"purple":$("input[name=purple]:checked").val()
};
如何仅获得橙色值?
字典代码有错误:
var values = {
"orange":$("input[name=orange]:checked").val(),
"blue":$("input[name=blue]:checked").val(),
"green":$("input[name=green]:checked").val(),
"purple":$("input[name=purple]:checked").val()
};
我在找那个 sheet.getRange(1,1).setValue([values["orange"]])
解决方案
尝试这个:
function runsies(values){
var sheet = SpreadsheetApp.getActiveSheet();
sheet.getRange(1,1,4,1).setValues([[values.orange],[values.blue],[values.purple],[values.green]]);
Logger.log(values);
};
推荐阅读
- javascript - 为什么我的程序不起作用
- java - 评估最大值和最小值,但为什么显示不正确的值?
- c# - 如何卸载没有升级机制的 WiX 包
- azure - 应用程序实体 appId 属性类型的更改
- mysql - mysql复制中奇怪的缓慢性能
- node.js - npm start 不运行反应项目
- c# - 在框架“netcoreapp2.0”和 RID“debian.8-x64”上使用 PostSharp 构建错误
- python - 对python气泡进行排序
- android - 为什么android.arch.navigation会导致程序类型已经存在:android.support.v4.os.ResultReceiver$1?
- shell - 编写一个 shell 脚本来找到一个二项式系数 c(n,k)