如何解决Google 表单 onSubmit 触发事件响应为空
我有一个链接到触发器的 Google 表单。当 onSubmit 事件被触发时,我得到一个空的响应对象
function setupTriggers() {
ScriptApp.newTrigger('onSubmit')
.forForm('1n78vh9LfdubCdKY4hcMZXEyYZw7ZxdE689-ihhczPow')
.onFormSubmit()
.create();
}
function onSubmit(e) {
console.log(JSON.stringify(e));
}
日志
{"authMode":"FULL","response":{},"source":{},"triggerUid":"1655010400613789390"}
提交表单时触发事件,但事件响应为空。
我在配置触发器时是否遗漏了任何步骤?
解决方法
事件对象不是空的,只是一些对象,即FormResponse和Form,没有可以字符串化的属性。
您必须使用链接文档中指示的适当方法访问这些对象中的相关数据。
,尝试这样的事情:
function setupTriggers() {
ScriptApp.newTrigger('onMyFormSubmit').forForm(FormApp.getActiveForm()).onFormSubmit().create();
}
function onMyFormSubmit(e) {
console.log(JSON.stringify(e));
var formResponse = e.response;
var itemResponses = formResponse.getItemResponses();
itemResponses.forEach(r=>{
console.log('Id: %s\nType: %s\nTitle: %s\nResponse: %s\n',r.getItem().getId(),r.getItem().getType(),r.getItem().getTitle(),r.getResponse());
});
}
我的表单只有两个问题,以下是该表单的执行情况:
Cloud logs
May 4,2021,3:39:39 PM Debug {"authMode":"FULL","response":{},"source":{},"triggerUid":"7825823049830695122"}
May 4,3:39:39 PM Debug Id: 1518756049
Type: MULTIPLE_CHOICE
Title: COL1
Response: 6
May 4,3:39:39 PM Debug Id: 1430799996
Type: MULTIPLE_CHOICE
Title: COL2
Response: 2
响应对象不为空。使用以下参考资料,您仍然可以获得您的回复。但是,如果您查看电子表格的 onformSubmit 触发器,则获取这些信息会容易得多。它的事件对象更易于访问。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。