我正在尝试处理 Google Apps 脚本 doGet(e) 方法中的查询参数。我定义了以下简单的 doGet() 函数,该函数根据参数(或缺少参数)提供不同的 html。
function doGet(e) {
Logger.log('In doGet');
Logger.log('query params: ' + e);
var isNull = (e.queryString == null);
var len = e.parameters.length;
Logger.log('query string is null: ' + isNull);
Logger.log('number of params: ' + len);
if (e.queryString == null) { //doesn't work!
Logger.log('Serving loginUI');
return HtmlService
.createHtmlOutputFromFile('loginUI')
.setSandboxMode(HtmlService.SandboxMode.IFRAME)
.addMetaTag('viewport', 'width=device-width, initial-scale=1')
.setTitle("Please log in");
}
//if here, we know query string is NOT null
if (e.parameter.mode == "player") {
return HtmlService
.createHtmlOutputFromFile('playerUI')
.setSandboxMode(HtmlService.SandboxMode.IFRAME)
.addMetaTag('viewport', 'width=device-width, initial-scale=1')
.setTitle("Following Player");
}
if (e.parameter.mode == "hole") {
return HtmlService
.createHtmlOutputFromFile('playerUI')
.setSandboxMode(HtmlService.SandboxMode.IFRAME)
.addMetaTag('viewport', 'width=device-width, initial-scale=1')
.setTitle("Following Hole");
}
if (e.parameter.mode == "flex") {
return HtmlService
.createHtmlOutputFromFile('flexUI')
.setSandboxMode(HtmlService.SandboxMode.IFRAME)
.addMetaTag('viewport', 'width=device-width, initial-scale=1')
.setTitle("Flex Interface");
}
}
正如您从我的日志代码中看到的,我正在努力找出最初在没有查询参数的情况下调用 doGet() 的情况下的 e 参数是什么。日志输出如下:
> [17-10-24 18:14:48:557 PDT] Starting execution [17-10-24 18:14:48:565
> PDT] Logger.log([In doGet, []]) [0 seconds] [17-10-24 18:14:48:566
> PDT] Logger.log([query params: [object Object], []]) [0 seconds]
> [17-10-24 18:14:48:566 PDT] Logger.log([query string is null: false,
> []]) [0 seconds] [17-10-24 18:14:48:567 PDT] Logger.log([number of
> params: undefined, []]) [0 seconds] [17-10-24 18:14:48:568 PDT]
> Execution succeeded [0.003 seconds total runtime]
e.parameters 中没有查询参数的情况如何处理?在这种情况下,e 似乎未定义。有什么想法吗?
作为后续问题,我的想法是在与 doGet 提供的 html 文件关联的 javascript 中构建查询字符串。例如,在上面代码中引用的“loginUI.html”文件中,我想包含使用不同参数调用 google.script.run.doGet() 的 jquery 代码,如下所示:
<script>
$("#playerUI").click(function () {
var queryString = "?mode=player";
google.script.run.doGet(queryString);
});
$("#holeUI").click(function () {
var queryString = "?mode=hole";
google.script.run.doGet(queryString);
});
$("#flexUI").click(function () {
var queryString = "?mode=flex";
google.script.run.doGet(queryString);
});
</script>
我的感觉是这也行不通。请指教。
e.parameters 中没有查询参数的情况如何处理?在这种情况下,e 似乎未定义。有什么想法吗?
function doGet(e) {
Logger.log('queryString is an empty string: ' + (e.queryString === ''));
Logger.log('parameter hasn\'t members: ' + (Object.keys(e.parameter).length === 0));
}
要写入 Google Apps 脚本编辑器记录对象的内容,请使用
JSON.stringify(object)
。
示例:
function doGet(e) {
Logger.log(JSON.stringify(e));
}
上面的代码在日志中打印了以下文本:
[17-10-24 21:13:28:414 CDT] {"参数":{},"contextPath":"","contentLength":-1,"queryString":"","参数":{ }}
如您所见,有几个命名值,:
参考
注意:第一个参考文献说,当未指定查询字符串时,queryString 返回
null
,但在我所做的测试中,情况并非如此。
是的,也许 doGet(e) 函数只是一个例子,因为我也多次遇到错误,然后我用 request 替换了参数,它就工作了。 你尝试这样做,但是当它执行时,它会在日志部分出现错误......我建议先尝试一下
function doGet(request) {
let page = request.parameter.page;
if (page == null) page = "Index";
var output = HtmlService.createTemplateFromFile(page);
return output.evaluate()
.addMetaTag('viewport', 'width=device-width , initial-scale=1')
.setXFrameOptionsMode(HtmlService.XFrameOptionsMode.ALLOWALL)
}
function myURL() {
return ScriptApp.getService().getUrl();
}
然后从 html 调用另一个文件,尝试如下所示
<a href="<?= myURL(); ?>?page=Index.html">Home</a>