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"}

提交表单时触发事件,但事件响应为空。

我在配置触发器时是否遗漏了任何步骤?

解决方法

事件对象不是空的,只是一些对象,即FormResponseForm,没有可以字符串化的属性。

您必须使用链接文档中指示的适当方法访问这些对象中的相关数据。

,

尝试这样的事情:

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 触发器,则获取这些信息会容易得多。它的事件对象更易于访问。

Interface Item Methods

Class ItemResponse

Google Sheets Events

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...