我有一个Google App脚本,它使用沙盒模式为IFRAME
呈现自定义样式和脚本的html页面,并且每个人都可以通过授权访问它。
Code.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()
获取的网址是错误的。但如果省略setSandboxMode(HtmlService.SandboxMode.IFRAME)
,它会提供正确的网址,但这次我的应用程序样式无法正常工作且看起来很直接。
更新:
我正在访问这样的主页(工作) - https://script.google.com/macros/s/<script>/dev?page=index
如上所述进行访问时,会生成错误的网址。
实际发布的链接是 - https://script.google.com/macros/s/<script>/exec
答案 0 :(得分:2)
{{1}}是你的线索。开发模式链接到当前代码,而exec链接到已发布的版本。
您将返回解析开发脚本的URL。
保存代码并发布最新版本。应该按预期工作