javascript - 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 类来通知他们。容器绑定脚本不是一个选项,因为此脚本的大小很大并且可以在多个文件上运行。
解决方案
- 当电子表格的单元格被匿名编辑时,您希望显示一条消息。
- 电子表格作为编辑者公开共享给匿名用户。
如果我的理解是正确的,这个答案怎么样?不幸的是,即使使用安装的 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 秒,然后删除图像。
结果:
笔记:
- 当然,您可以创建一个图像用于与脚本一起显示。但在这种情况下,工艺成本会变高。结果,直到显示图像的时间变长。所以我建议使用预先创建的图像。
参考:
如果我误解了您的问题并且这不是您想要的方向,我深表歉意。
推荐阅读
- join - 如何使用 JdbcContext 在 Apache Metamodel 中表示 Self join?
- mysql - 在 Golang 从数据库中读取时区分空对象和空值
- python - pandas.read_excel 和 to_excel 仅使用最大的工作表或具有最多列的工作表
- c++ - 从 ESPAsyncWebServer 请求参数读取数据时出现大师冥想错误
- latex - 在乳胶中左右移动文本
- javascript - ReactJS 不保存对象
- css - 单击后如何使锚标记禁用或启用
- angular - 下载来自 Angular 中的 Java REST API 的 .doc
- sql - 如何从 bigquery 中的结构中删除行
- java - 类型不匹配无法从 Integer 转换为 Optional