Javascript 在IFRAME沙盒模式下获取Google应用程序脚本中的错误url
我有一个Google应用程序脚本,它以自定义样式呈现我的html页面,并使用沙盒模式(如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) {
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
保存代码并发布最新版本。然后应该像预期的那样工作