0

我有一个带有嵌入式 Apps 脚本小工具的 Google 协作平台页面。在页面上,我想在单击按钮时显示 ScriptDb 数据。

我的问题是:如何将 ScriptDb 结果传递给嵌入在我的小工具中的 JavaScript?

这是我的来源:

[示例代码.gs]

function doGet() {
  // return template page
  return HtmlService
      .createTemplateFromFile('Sample-HTML')
      .evaluate().setSandboxMode(HtmlService.SandboxMode.NATIVE);
}

function include(filename) {
  return HtmlService.createHtmlOutputFromFile(filename)
      .getContent();
}

// assume db contains 10 'records'
function getData(query) {
  var db = ScriptDb.getMyDb(); 
  var data = db.query(query);
  Logger.log(data.getSize()); // returns '10.0'
  return data; // makes showData think this is null
}

[示例-HTML.html]

<?!= include('Sample-JavaScript'); ?>

<input type="button" value="show data"
    onclick="google.script.run
    .withSuccessHandler(showData)
    .getData({})" />

[示例-JavaScript.html]

<script>
function showData(db_query_result) {
alert(db_query_result); // returns null.
}
</script>
4

1 回答 1

1

返回的值是文档db.query()中定义的对象,不能直接在您的 UI 中使用,您应该以可以在页面中显示的格式返回值:字符串或字符串数​​组。

我没有测试,但这应该工作:

function getData(query) {
  var db = ScriptDb.getMyDb(); 
  var result = db.query(query);
  Logger.log(result.getSize()); // returns '10.0'
  var results = db.query({type: 'person'});
  var data = [];
  while (results.hasNext()) {
   data.push(results.next());
  }
  return data; // data is an array of results
}
于 2013-09-29T10:30:40.923 回答