首页 > 解决方案 > Google Apps 脚本 toast 消息不会显示给匿名编辑者

问题描述

我在可安装的 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 类来通知他们。容器绑定脚本不是一个选项,因为此脚本的大小很大并且可以在多个文件上运行。

标签: javascriptgoogle-apps-scriptgoogle-sheets

解决方案


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

如果我的理解是正确的,这个答案怎么样?不幸的是,即使使用安装的 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 秒,然后删除图像。

结果:

在此处输入图像描述

笔记:

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

参考:

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


推荐阅读