首页 > 解决方案 > 通过 GmailApp.sendEmail 在电子邮件的 html 正文中使用电子表格值

问题描述

我有一个脚本,它使用带有 html 正文的 GmailApp 发送电子邮件。我希望 html 正文包含包含它的电子表格中的特定值,但是每次发送电子邮件时,我添加的 scriptlet 都会显示为纯文本。

电子邮件.gs:

function sendEmail() {



  var mailTo = 'example@gmail.com'


  var NAME = SpreadsheetApp.getActiveSheet().getRange('Sheet1!A1').getValue();


  var subject = 'Hello!'
  var html = HtmlService.createHtmlOutputFromFile('body').getContent();



  GmailApp.sendEmail('', subject, '', {


    name: 'Friend',
    htmlBody: html,
    bcc: mailTo


  });


}

正文.html:

<h1>Good Evening, <? NAME ?> </h1>
<h3>Hello Friend!</h3>

每当运行脚本时,都应从工作表中的指定单元格中提取“NAME”。

我猜它显示为文本的原因是 GmailApp.sendEmail 将原始 html 粘贴到电子邮件中并假设客户端会阅读它,那么我怎样才能首先让它通过脚本处理然后粘贴到电子邮件中?

标签: javascripthtmlgoogle-apps-script

解决方案


或者您可以使用 createTemplateFromFile 并注意“=”

function sendEmail() {
  var mailTo = 'example@gmail.com'
  var subject = 'Hello!'
  var html = HtmlService.createTemplateFromFile('body');
  html.NAME = SpreadsheetApp.getActiveSheet().getRange('Sheet1!A1').getValue();
  html = html.evaluate().getContent();

  GmailApp.sendEmail('', subject, '', {
    name: 'Friend',
    htmlBody: html,
    bcc: mailTo
  });

}

<h1>Good Evening, <?= NAME ?> </h1>
<h3>Hello Friend!</h3>

推荐阅读