Google Apps脚本-将来自应用脚本功能的输出返回给html文件javascript函数

时间:2018-08-01 14:13:11

标签: javascript google-apps-script google-sheets google-sheets-api

好吧,所以我试图在Google表格中创建一个函数,当用户选择一个单元格然后运行该函数(当前试图创建)时,应该会出现一个边栏,该边栏将获取该单词的所有同义词。我正在使用https://words.bighugelabs.com/来获取同义词。所以首先我做菜单:

`function onOpen(e) {
  var ui = SpreadsheetApp.getUi().createMenu("Sidebar")
  .addItem("Get Synonym", 'showSidebar')
  .addToUi();
}`

然后是showSidebar函数:

function showSidebar() {
      var html = HtmlService.createHtmlOutputFromFile("Test")
      .setSandboxMode(HtmlService.SandboxMode.IFRAME)
      .setWidth(150)
      .setTitle("My Sidebar");
      SpreadsheetApp.getUi().showSidebar(html);
    }

这是html文件:

<!DOCTYPE html>
<html>
<head>
<base target="_top">
<script>

function doSomething() {
var synonyms = google.script.run.getSynonym();
document.getElementById("synonyms").innerHTML = synonyms;
}

</script>
</head>
<body>
<div>
<span style="color:orange;">This is a test sidebar!</span>
<button onclick="doSomething()">Click Me!</button>
<div id="synonyms"></div>
</div>
</body>
</html>

这是getSynonym函数:

function getSynonym() {
  var word = SpreadsheetApp.getActiveRange().getValue();
  var synonyms = [];
  var response = UrlFetchApp.fetch("http://words.bighugelabs.com/api/2/{my_api_key}/" + word + "/json");
  response = JSON.parse(response);
  var synonyms = response.adjective.syn;
  return synonyms;
}

但是作为同义词数组的变量同义词不会返回到Html文件中的doSomething函数。

我想要的是侧边栏应获取所有同义词的列表。 因此,基本上我无法将数据从一个函数传递到另一个函数……而我想知道这是否是正确的方法。

1 个答案:

答案 0 :(得分:3)

使用google.script.run调用服务器端函数时,您需要定义一个成功处理程序,该处理程序将异步接收您的响应。

请参见以下示例:https://developers.google.com/apps-script/guides/html/communication

  function onSuccess(synonyms ) {
    console.log(synonyms);
  }

  google.script.run.withSuccessHandler(onSuccess).doSomething();