【发布时间】:2018-08-09 01:13:59
【问题描述】:
我正在尝试将一些内容放入来自 Google Apps 脚本的自动回复消息中。我的项目有一个 AutomatedResponseTemplate.html 脚本命中一些响应 HTML 字符串来发送。该文件的定义如下:
<!DOCTYPE html>
<html>
<head>
<script src=https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js></script>
<script src=https://cdnjs.cloudflare.com/ajax/libs/mustache.js/2.3.1/mustache.js></script>
<script>
$(function() {
let data = <?= JSON.stringify(messageData) ?>
// make request to "server"
template = $('body').html()
rendering= Mustache.render(template, data)
$('body').html(template)
})
</script>
<style>
#closing {
white-space: pre-line;
}
.separate-lines {
white-space: pre-line;
}
.first {
width: 80px;
}
.left {
float: left;
}
</style>
</head>
<body>
<p>
{{name}}
</p>
<p>
Thank you for reaching out to us! This is an automated reply, and one of us shall reach out to you,
for real, shortly. Here is a copy of the message you sent us for reference:
</p>
<p>
<blockquote class=separate-lines>
<span><label class="first left">Sender:</label> {{sender}}</span>
<span><label class="first left">Subject:</label> {{subject}}</span>
<span><label class="first left">Message:</label> {{message}}</span>
</blockquote>
</p>
<p id=closing>
Mike Warren
Open Source Roads
</p>
</body>
</html>
为了分离关注点并保持 RESTful,我让脚本通过该标签将相关数据发送到 HTML。 There's a working pure-client-side version prior 和implementation here 的想法让我有了这样做的想法。
有一个问题:它不起作用。即使我附加了一些非模板代码
$('#data').text('This was inserted by jQuery')
还有一个标签
<p id=data></p>
...没有任何变化。
世界上到底发生了什么?
更新
我将<script> 标签更新为:
<script>
$(function() {
let data = <?!= JSON.stringify(messageData.data) ?>
// make request to "server"
template = $('body').html()
rendering= Mustache.render(template, data)
$('body').html(rendering)
$('#data').text('This text was inserted by jQuery')
})
</script>
,用引号将客户端依赖项上的 src 值括起来(我知道为什么这对 Google Apps 脚本很重要,因为它在其他地方工作正常),并提供了一个 doGet 用于调试目的:
function doGet(e) {
var messageData = {
data: {
sender: 'mwarren04011990@gmail.com',
name: 'Test User',
recipient: Session.getActiveUser().getEmail(),
subject: 'Test email',
message: 'Hello world'
}
}
var template = HtmlService
.createTemplateFromFile('AutomatedResponseTemplate')
template.messageData = messageData
return template
.evaluate()
.setSandboxMode(HtmlService.SandboxMode.IFRAME)
}
此外,应该将此客户端模板呈现为字符串的函数具有以下代码:
/**
* Generates an email message body in response to the sender's `messageData`
* @param {object} messageData - a JSON object with at least the following:
* - `sender`
* - `name`
* - `subject`
* - `message`
*/
function getAutomatedResponseTo(messageData) {
messageData = messageData || {};
if (!messageData.sender) return '';
if (!messageData.name) return '';
if (!messageData.subject) return '';
if (!messageData.message) return '';
var template = HtmlService
.createTemplateFromFile('AutomatedResponseTemplate')
template.messageData = messageData;
return template
.evaluate()
.setSandboxMode(HtmlService.SandboxMode.IFRAME)
.getContent()
}
我试图以这种方式分离关注点是否不可行?
【问题讨论】:
-
你遇到了什么错误?
-
你为什么在谷歌应用脚本中使用
{{ }}?我认为它们不受支持,而是使用<?= ?> -
如何将数据传递给模板?
-
{{}}是 Mustache.js 使用的胡须。 github.com/janl/mustache.js 。至于错误,我没有收到,但是当电子邮件发送时,胡子不会被它们应该代表的数据替换
标签: javascript jquery google-apps-script mustache