0

我正在从这里完成教程:https ://developers.google.com/apps-script/api/quickstart/js 。当我尝试使用客户端 ID 和 API 密钥插入在窗口平台上本地运行 quickstart.html 时,它会在第 144 行抛出错误:

未捕获的 SyntaxError:无效或意外的令牌。
未捕获的 ReferenceError:handleClientLoad 未在 HTMLScriptElement.onload 中定义

在完成本快速入门之前,我是否错过了其他需要启用的功能?

4

1 回答 1

0

我认为 Google 示例脚本中存在一些问题。我发现和修改的是,

  1. 脚本标签上的 async 和 defer 属性

您可能想要使用 async 属性,但快速解决方法是删除 async 并将 defer 添加到第一个和第二个脚本标签。

    <pre id="content"></pre>
    <!-- add defer to the first script tag -->
    <script defer type="text/javascript">
    ...
    <!-- remove async from the 2nd tag -->
    <script defer src="https://apis.google.com/js/api.js"
  1. callAppsScript 函数中字符串的语法错误。

这似乎是转义语法错误和网页中示例代码的换行符处理的结合。以下是我修改的代码的工作片段。

    resource: {
          files: [{
            name: 'hello',
            type: 'SERVER_JS',
            source: 'function helloWorld() {\n  console.log("Hello, world!");\n}'
          }, {
            name: 'appsscript',
            type: 'JSON',
            source: "{\"timeZone\":\"America/New_York\",\"exceptionLogging\":\"CLOUD\"}"
          }]
  1. 调用不存在的函数

示例代码调用callScriptFunction里面updateSigninStatus不存在。它必须是callAppsScript,但后者需要一个参数。

我将调用替换为callScriptFunction();以下内容,并且它起作用了。

callAppsScript(gapi.auth2.getAuthInstance());

通过进行上述更改,示例可以在服务器端创建一个新脚本,但在更新它时会返回错误。所以看起来示例代码中还有一些潜在的问题,但这是另一个问题,与原始问题无关,我猜。

于 2018-03-21T07:57:31.050 回答