javascript - Google Apps 脚本属性服务 Obj 文字中的意外标记

标签 javascript google-apps-script google-forms

我正在使用 Google Apps PropertyService 来存储一些设置变量。当我使用 setProperties() 函数并给它一个对象(就像他们在 documentation 中所做的那样)然后尝试获取一个属性并解析它时,我得到一个 SyntaxError: Unexpected Token in Object Literal.

在我运行这段代码之前,PropertiesService 被清空。据我所知,我得到了一个字符串,我应该能够将其解析为一个对象。

function setDefaults(){
  var def = {
    config: {
      isSetup: false
    },
    test: {
      page: true
    }
}

var docServ = PropertiesService.getDocumentProperties();
docServ.setProperties(def, true);

log(typeof docServ.getProperty("config")); //string
log(docServ.getProperty("config")); //{isSetup=false}
log(JSON.parse(docSer.getProperty("config"))); //SyntaxError
}

最佳答案

这个问题似乎与多个嵌套对象有关。显然,JSON 解析器只能向下一级。

在每个嵌套对象上调用 JSON.stringify() 为我解决了这个问题:

 var def = {config: {isSetup: false}, test: {page: true}};

  for (var prop in def) {

    def[prop] = JSON.stringify(def[prop]);

  }

var docServ = PropertiesService.getDocumentProperties();
docServ.setProperties(def, true);

var config  = JSON.parse(docServ.getProperty("config"));

Logger.log(config.isSetup); //logs 'false'

关于javascript - Google Apps 脚本属性服务 Obj 文字中的意外标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48675245/

相关文章:

javascript - Google Apps 脚本(日历)- 比较 2 个事件是否在同一天

google-apps-script - 更改日历事件颜色

google-apps-script - 取消表单与工作表的链接

c - 如何直接发布到 Google Docs 表单

javascript - 如何在 querySelector 中组合属性和第 n 个类型?

javascript - 用JS提交表单不进行基本验证

javascript - XSLT 和 MathJax

javascript - 我可以在嵌套在 'index' 中的 'v-for' 中使用 'method' 参数吗?

javascript - "Document is missing (perhaps it was deleted?)"引用刚刚创建的文档

google-apps-script - 是否可以使用谷歌电子表格中的数据来 'prefill' 谷歌表单?