我使用未附加的Google Apps脚本发送格式化的HTML电子邮件。我正在尝试将内嵌图像附加到格式化的HTML文件中,并且电子邮件完美地工作,并且图像在电子邮件中内嵌,但它们内联在电子邮件的最底部,而不是我希望它们的位置。
我正在使用的脚本位于下方,HTML电子邮件位于其下方。
function sendInlineImages() {
var email = [Email address]
var subject = "Email Subject";
var body= HtmlService.createHtmlOutputFromFile('moving').getContent();
// Image URLs, under CC license
var jasper1URL = "http://cat-bounce.com/cb.png";
var jasper2URL = "http://cat-bounce.com/cb.png";
var jasper3URL = "http://cat-bounce.com/cb.png";
// Fetch images as blobs, set names for attachments
var jasper1 = UrlFetchApp
.fetch(jasper1URL)
.getBlob()
.setName("jasper1URL");
var jasper2 = UrlFetchApp
.fetch(jasper2URL)
.getBlob()
.setName("jasper2URL");
var jasper3 = UrlFetchApp
.fetch(jasper3URL)
.getBlob()
.setName("jasper3URL");
var htmlEverything = body +
'<img src="cid:jasper1URL" alt="Jasper 1" width="220">'
+ '<img src="cid:jasper2URL" alt="Jasper 2" width="220">'
+ '<img src="cid:jasper3URL" alt="Jasper 3" width="200">'
// Send message with inlineImages object, matching embedded tags.
GmailApp.sendEmail(email, subject, "",
{ htmlBody: htmlEverything,
inlineImages:
{
jasper1URL: jasper1,
jasper2URL: jasper2,
jasper3URL: jasper3,
}
});
}
HTML电子邮件在此处,图像位于嵌套表格中。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<meta name="format-detection" content="telephone=no"/>
<meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; user-scalable=no;"/>
<meta http-equiv="X-UA-Compatible" content="IE=9; IE=8; IE=7; IE=EDGE" />
<link href='https://fonts.googleapis.com/css?family=Montserrat' rel='stylesheet' type='text/css'/>
<title>Page title</title>
<style type="text/css">
@media screen and (max-width: 630px) {
}
</style>
</head>
<body style="padding:0; margin:0">
<table border="0" cellpadding="0" cellspacing="0" style="margin: 0; padding: 0" width="630px">
<tr>
<td align="center" valign="top" style="padding-bottom: 15px;" bgcolor="#fff">
</td>
</tr>
<tr>
<td align="center" valign="top" bgcolor="#000" style="padding-bottom: 5px; font-family: Montserrat, Verdana, sans-serif; font-size: 24px;">
<h1><font color="#fff">Information for you!</font></h1>
<h4><font color ="#fff">Additional Stuff
<p>From,</p>
<p>Me</p>
</font></h4>
</td>
</tr>
<tr>
<td align="center" valign="top" style="padding-bottom: 15px;" bgcolor="#d3d3d3">
</td>
</tr>
<tr bgcolor="#000">
<td align="center" valign="top">
<table border="0" cellpadding="10" bgcolor="#000" cellspacing="0" width="630" id="emailContainer">
<tr>
<td align="left" valign="top" >
<img src="cid:jasper1URL" alt="Jasper 1" width="220"></img>
</td>
<td align="center" valign="top" width="200">
<img src="cid:jasper2URL" alt="Jasper 2" width="200"></img>
</td>
<td align="right" valign="top" width="200px" >
<img src="cid:jasper3URL" alt="Jasper 3" width="200"></img>
</td>
</tr>
</table>
</td>
</tr>
<tr>
<td align="center" bgcolor="#000" valign="top">
</td>
</tr>
<tr>
<td align="center" bgcolor="#d3d3d3" valign="top" style="padding-top: 15px; padding-bottom: 15px; font-family: Monteserrat, Verdana, sans-serif;">
<font color="#000">Stuff that should be here in the email</font>
</td>
</tr>
<tr>
<td align="center" bgcolor="#000" valign="top">
</td>
</tr>
</table>
</body>
</html>
答案 0 :(得分:0)
由于以下代码,它们出现在电子邮件的末尾:
var htmlEverything = body +
'<img src="cid:jasper1URL" alt="Jasper 1" width="220">'
+ '<img src="cid:jasper2URL" alt="Jasper 2" width="220">'
+ '<img src="cid:jasper3URL" alt="Jasper 3" width="200">'
您的Html代码已经在嵌套表中定义了图像的位置,方法是将img标记添加到html代码的末尾,如上所述。您正在使内嵌图像复制到电子邮件的底部。
将此修改为
var htmlEverything = body
这样可以防止图片出现在电子邮件的底部
你最后的代码:
function sendInlineImages() {
var email = [Email address]
var subject = "Email Subject";
var body= HtmlService.createHtmlOutputFromFile('moving').getContent();
// Image URLs, under CC license
var jasper1URL = "http://cat-bounce.com/cb.png";
var jasper2URL = "http://cat-bounce.com/cb.png";
var jasper3URL = "http://cat-bounce.com/cb.png";
// Fetch images as blobs, set names for attachments
var jasper1 = UrlFetchApp
.fetch(jasper1URL)
.getBlob()
.setName("jasper1URL");
var jasper2 = UrlFetchApp
.fetch(jasper2URL)
.getBlob()
.setName("jasper2URL");
var jasper3 = UrlFetchApp
.fetch(jasper3URL)
.getBlob()
.setName("jasper3URL");
var htmlEverything = body
// Send message with inlineImages object, matching embedded tags.
GmailApp.sendEmail(email, subject, "",
{ htmlBody: htmlEverything,
inlineImages:
{
jasper1URL: jasper1,
jasper2URL: jasper2,
jasper3URL: jasper3,
}
});
}
您的Html代码保持不变!