也許這將是有用的人,因爲這個問題已經回答了。
我與玉的工作,這是很有挑戰性的想出來,在最後被證明是非常簡單:)
(PS:此代碼沒有經過優化,只是一個例子)
的js部分與nodemailer:
var nodemailer = require('nodemailer')
var jade = require('jade');
var config = {
// config for sending emails like username, password, ...
}
var emailFrom = '[email protected]';
var emailTo = '[email protected]';
var templateDir = 'path/to/templates/';
var transporter = nodemailer.createTransport(config);
var username = 'thisUsername'
// rendering html template (same way can be done for subject, text)
var html = jade.renderFile(templateDir+'/html.jade', {username: 'testUsername'});
//build options
var options = {
from: emailFrom,
to: emailTo,
subject: 'subject',
html: html,
text:'text'
};
transporter.sendMail(options, function(error, info) {
if(error) {
console.log('Message not sent');
console.log(info);
return false;
}
else{
console.log('Message sent: ' + info.response);
console.log(info);
return true;
};
});
html.jade
p test email html jade
p
| Username:
| !{username}
以下是使用email-templates和nodemailer的示例。
js文件:
var path = require('path');
var EmailTemplate = require('email-templates').EmailTemplate;
var transporter = nodemailer.createTransport(config);
var templateDir = path.join(__dirname, '/yourPath/emailTemplates', 'subdir');
var template = new EmailTemplate(templateDir)
var username = 'testUsername';
var transport = nodemailer.createTransport(config)
template.render(locals, function (err, results) {
if (err) {
return console.error(err)
}
// replace values in html template
console.log('template render')
console.log(err);
// default is results.html in this case
// read template and replace desired values
var res1 = results.html.toString();
var str = res1.replace('__username__', username);
console.log(str);
console.log('end template render')
transport.sendMail({
from: emailFrom,
to: emailTo,
subject: 'subject',
html: str,
text: results.text
}, function (err, responseStatus) {
if (err) {
return console.error(err)
}
console.log(responseStatus)
})
})
中將Html.HTML
test email html
username:
<div>
__username__
</div>
爲什麼不使用任何JS模板引擎的(玉石,EJS,鬍子)?這正是他們的任務。 – soulcheck 2014-09-28 13:06:37
它不適合客戶端使用,我需要它在服務器端發送電子郵件。我在服務器端使用Jade,但我不知道如何在這個特定的實例中利用Jade。 – MindWire 2014-09-28 13:36:18
@Mindware沒有什麼能阻止你在服務器端使用你選擇的模板引擎。這只是javascript。 – soulcheck 2014-09-28 13:48:25