我正在尝试使用 HTMLService 和 GAS 创建一个模式弹出窗口,对 Google 文档中的给定表格单元格执行一些操作。
弹出窗口有效,通常我可以将数据从服务器脚本传递到客户端脚本并返回。我似乎无法传递的数据是打开弹出窗口时光标所在的表格单元格。
方法 1:如果我将其直接传递给客户端并返回,则引用将被破坏,因为它在到达客户端时已为 null
。我可以在完全相同的上下文中很好地传递单元格的内容,因此字符串可以工作,这只是它是单元格引用的事实。 (很有道理。)
方法 2:如果我将 TableCell 引用存储在服务器端的全局变量中,我会得到 Cannot call method "getText"of undefined
--在第一次往返后引用未定义。 (我猜服务器脚本会在那时完全重新加载。)
方法 3:如果我在客户端使用 CacheService.getUserCache(),当我尝试获取缓存的 TableCell 对象时,它似乎与我设置的对象断开连接,因为我收到了迄今为止无法通过 Google 搜索的错误 Cannot在对象TableCell中找到函数getText。
// server, before popup is opened:
cache.put('cell_currently_being_edited', active_doc.getCursor().getElement().getParent());
// popup client calls server function like so:
google.script.run.withSuccessHandler(load_content).get_starting_content();
// server, where the above error occurs:
function get_starting_content() {
var cell_currently_being_edited = cache.get('cell_currently_being_edited');
return cell_currently_being_edited.getText();
}
如果单元格具有某种我可以传递的固定 ID 值,那就可以工作......
我会根据单元格中的文本来执行此操作,但我希望这不是唯一的选择,因为一般来说单元格文本(是的,在这个特定上下文中也是如此)可能不是唯一的,所以在往返之后我当用户激活弹出窗口时,最终可能会替换光标所在的其他单元格中的文本。
最佳答案
解决方案:
- 您可以使用单元索引作为唯一标识符在客户端和服务器之间来回传递 RC 字符串,因为字符串值是合法的。
- 使用属性/缓存服务将 RC 索引信息存储为字符串,以便将来在服务器中检索(如果需要)。
示例脚本:
function getRCTIndexOfTable(tableCell) {
var tableRow = tableCell.getParentRow();
var table = tableRow.getParentTable();
var column = tableRow.getChildIndex(tableCell);
var row = table.getChildIndex(tableRow);
var body = table.getParent().asBody();
var tableId = body.getChildIndex(table);
return 'R' + row + 'C' + column + 'T' + tableId;
}
function main() {
var active_doc = DocumentApp.getActiveDocument();
var activeTableCell = active_doc
.getCursor()
.getElement()
.getParent()
.asTableCell();
Logger.log(getRCTIndexOfTable(activeTableCell));
}
引用文献:
关于javascript - 在服务器-客户端往返期间存储(或传递)Element/TableCell 引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52659246/