gpt4 book ai didi

javascript - 在服务器-客户端往返期间存储(或传递)Element/TableCell 引用

转载 作者:行者123 更新时间:2023-11-29 20:49:25 26 4
gpt4 key购买 nike

我正在尝试使用 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/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com