匿名编辑者不会显示 Google Apps Script toast 消息

IT技术 javascript google-apps-script google-sheets
2021-03-18 13:49:47

我在可安装的 onEdit 触发器函数中调用 toast 消息,每当进行编辑时,该函数就会在 Google 表格界面中显示一条消息。对于登录其 Google 帐户的用户,该消息按预期显示,但当编辑者为匿名时,它不会显示在界面中。

我有一个启用了匿名编辑的表格文件(“知道链接的任何人”)。有一个独立的 Google Apps 脚本项目已经安装了一个可安装的 onEdit 触发器。函数中的所有内容都对匿名用户和登录用户成功执行,但 toast 消息除外,该消息仅对登录用户显示。

可安装的 onEdit 触发器被设置为执行 showMessage 函数。

触发器安装:

ScriptApp.newTrigger('showMessage').forSpreadsheet('thefileid').onEdit().create();

显示消息功能:

function showMessage(e) {

    var msg = 'Some msg';
    var title = 'Some title';
    var file = e.source;
    var activeSheet = file.getActiveSheet();
    file.toast(msg, title);

    // do other things

}

Toast 消息显示给登录用户,而不是匿名用户。函数中的“其他事物”按每个人的预期工作。我正在寻找一种向匿名用户显示该消息的方法(或寻找某种方式向他们传达自动消息)。脚本项目是独立的而不是容器绑定的,所以我不能使用 Ui 类来通知他们。容器绑定脚本不是一种选择,因为此脚本的大小很大并且可以在多个文件上运行。

2个回答
  • 您希望在电子表格的单元格被匿名编辑时显示一条消息。
  • 电子表格作为编辑者公开共享给匿名用户。

如果我的理解是正确的,这个答案怎么样?不幸的是,即使使用已安装的 OnEdit 事件触发器,在编辑匿名用户时,toast()也无法使用 Class Ui。因此,作为几种解决方法之一,我想建议使用图像。幸运的是,insertImage()可以用于这种情况。所以我正在使用这个解决方法。请将此视为几个答案之一。

在使用此脚本之前,请准备好要显示的图像。

示例脚本:

在使用此脚本之前,请设置图像的文件 ID。并请安装 OnEdit 事件触发器以实现showMessage().

function showMessage(e) {
  var fileId = "###"; // Please set the file ID of the image.

  var sheet = e.source.getActiveSheet();
  var blob = DriveApp.getFileById(fileId).getBlob();
  var image = sheet.insertImage(blob, 2, 3);
  Utilities.sleep(3000);
  image.remove();
}
  • 在这个示例脚本中,当编辑单元格时,显示准备好的图像并等待 3 秒,然后删除图像。

结果:

在此处输入图片说明

笔记:

  • 当然,您可以创建一个图像与脚本一起显示。但在这种情况下,工艺成本会变得很高。结果,直到显示图像的时间变长。所以我建议使用预先创建的图像。

参考:

如果我误解了您的问题并且这不是您想要的方向,我深表歉意。

我的意思是当多人同时访问文档时。不过,这是一个很好的解决方法,我目前正在使用它。
2021-04-20 13:49:47
谢谢你的主意!这似乎对所有匿名和登录的用户都有效,尽管当文件有多个编辑器时它会卡在 image.remove() 上。执行时间从 7s 到 25s,再到 80s。直到我关闭匿名编辑器的浏览器,80 秒的执行才停止。这对我来说似乎是一个合理的解决方法,尽管我不会将其标记为“the”答案,因为我怀疑 toast 功能实际上存在问题。
2021-05-03 13:49:47
是的,没错。我目前正在使用您的 insertImage() 解决方法。
2021-05-04 13:49:47
@gccree 谢谢你的回复。您通过共享多个用户来使用一个电子表格。我的理解正确吗?我能问一下你目前的解决方法吗?
2021-05-18 13:49:47
@gccree 谢谢你的回复。我带来的不便表示歉意。不幸的是,我无法理解when the file has multiple editors. 我可以问你有关它的详细信息吗?由于谷歌方面的规范,“toast 功能”不能用于您的情况,我深表歉意。我找不到其他解决方法来使用“吐司功能”的情况是由于我的技能不佳。我也必须为此道歉。
2021-05-19 13:49:47

正如您在文档中看到的

Apps 脚本需要用户授权才能访问来自内置 Google 服务高级 Google 服务的私人数据

这意味着您可以与任何人共享您的脚本,但他们需要登录才能使用该脚本。