Javascript 在IFRAME沙盒模式下获取Google应用程序脚本中的错误url

Javascript 在IFRAME沙盒模式下获取Google应用程序脚本中的错误url,javascript,html,google-apps-script,google-apps,Javascript,Html,Google Apps Script,Google Apps,我有一个Google应用程序脚本,它以自定义样式呈现我的html页面,并使用沙盒模式(如IFRAME)呈现脚本,每个人都可以通过授权访问它 代码.gs function getScriptUrl() { var url = ScriptApp.getService().getUrl(); console.log(ScriptApp.getService()); return url; } function doGet(e) { if (!e.parameter.page) {

我有一个Google应用程序脚本,它以自定义样式呈现我的html页面,并使用沙盒模式(如
IFRAME
)呈现脚本,每个人都可以通过授权访问它

代码.gs

function getScriptUrl() {
 var url = ScriptApp.getService().getUrl();
  console.log(ScriptApp.getService());
 return url;
}

function doGet(e) {
  if (!e.parameter.page) {
    // When no specific page requested, return "home page"
    return HtmlService.createTemplateFromFile('index').evaluate()
        .setTitle('L1 - UX')
        .setSandboxMode(HtmlService.SandboxMode.IFRAME);
  }
  // else, use page parameter to pick an html file from the script
  return HtmlService.createTemplateFromFile(e.parameter['page']).evaluate()
      .setTitle('L1 - UX')
      .setSandboxMode(HtmlService.SandboxMode.IFRAME);
}

function include(filename) {
  return HtmlService.createHtmlOutputFromFile(filename)
      .setSandboxMode(HtmlService.SandboxMode.IFRAME)
      .getContent();
}
index.html

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <!-- stylesheets -->
        <?!= include('stylesheets'); ?>        
    </head>
    <body>
        <?var url = getScriptUrl();?>
         <!-- application content -->
         <div class="container-fluid">
          <div class="row">
            <!-- left sidebar -->
            <div class="col-sm-3 col-md-2 sidebar">
              <ul class="nav nav-sidebar">
                <li><a href='<?=url?>?page=overview'>Overview</a></li>
                <li class="active"><a href='<?=url?>?page=index'>Form</a></li>
                <li><a href='<?=url?>?page=report'>Reports</a></li>
                <li><a href='<?=url?>?page=export'>Export</a></li>
              </ul>
            </div> <!-- left sidebar -->
            <!-- main content -->
            <div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 main">
               <h2 class="sub-header">Content</h2>
            </div> <!-- main content -->
           </div>
         </div> <!-- application content -->
         <!-- JavaScripts -->
         <?!= include('javascripts'); ?>
    </body>
</html>

内容
这里,我从
ScriptApp.getService().getUrl()
获取的url是错误的。但是如果我省略了
setSandboxMode(HtmlService.SandboxMode.IFRAME)
,它给出了正确的url,但这次我的应用程序样式无法正常工作,而且看起来像有线的

更新:

我正在这样访问主页(工作)-
https://script.google.com/macros/s//dev?page=index

当像上面那样访问时,它生成了错误的url


实际发布的链接是-
https://script.google.com/macros/s//exec
/dev
是你的线索。开发模式链接到当前代码,而exec链接到发布的版本

您正在返回开发脚本解析到的URL

保存代码并发布最新版本。然后应该像预期的那样工作