我正在开发一个与电子表格绑定的 Google Apps Script 项目。在某个模式对话框中,HTML 客户端函数clientFunc
会构建一个 Map<number, number> 对象和一个数组,然后将其作为参数传递给服务器端 Apps Script 函数serverFunc
。
该clientFunc
函数执行的所有操作都正确无误google.script.run.serverFunc(map, array);
,直到此时我收到标题中描述的未捕获的错误:
TypeError:由于属性中的非法值而失败:0
以下是一些见解:
- 问题在于 Map 对象部分,因为当仅使用数组参数时,一切都运行良好。
- 服务器端函数从未被调用:它从未显示在 Apps Script 的“执行”选项卡中。此外,每当我使用完全相同的参数在 Apps Script 端直接运行此服务器端函数时,它都会按预期工作。
- Map 对象已正确构建,或者至少当我将其登录到控制台时这是我推断出来的:
- 当我修改代码以使用 Object 而不是 Map 时,它突然就正常工作了。所以我可以让它工作,但此时我只是好奇,我想知道到底发生了什么。此外,Map(而不是普通的对象)正是我所需要的,因为(除其他外)我正在处理数字。
- 我想知道问题是否在于无法将 Map 作为参数传递给服务器端函数,但文档似乎并没有表明这一点:
合法的参数和返回值是 JavaScript 基元,例如数字、布尔值、字符串或 null,以及由基元、对象和数组组成的 JavaScript 对象和数组。页面中的表单元素作为参数也是合法的,但它必须是函数的唯一参数,并且作为返回值是不合法的。如果您尝试传递除表单之外的日期、函数、DOM 元素或其他禁止类型(包括对象或数组内的禁止类型),请求将失败。创建循环引用的对象也将失败,并且数组中未定义的字段将变为 null。
如果有人知道问题出在哪里,我洗耳恭听!提前致谢。
Map
您无法通过接口发送对象google.script.run
,因为 Map 无法被序列化。来自文档:
因此,要么使用普通的 vanilla
Object
,要么在发送端和接收端使用自己的替换器和复活器Map
函数进行序列化。JSON.stringify()
JSON.parse()