无法使用节点电子邮件模板将变量传递给pug / jade模板

时间:2017-08-28 17:39:33

标签: node.js templates pug email-templates

我尝试使用节点电子邮件模板呈现一个哈巴狗/玉石模板。

                var confirmCode = generateConfirmCode(configPublic.confirmCodeLength);
                var query = querystring.stringify({
                    code: confirmCode,
                    id: user._id.toString()
                });

                var templateDir = path.join(__dirname, '../templates', 'confirmation-email');
                var confirmEmail = new EmailTemplate(templateDir);
                var confirmUrl = configPublic.url + '/user/email/confirm?' + query;
                var templateVals = {url: confirmUrl};

                confirmEmail.render(templateVals, function(err, result) {
                    if (err) {
                        console.log(err);
                    }
                    var mailOptions = {
                        from: configPrivate.gmail.username,
                        to: user.email.address,
                        subject: 'confirmation',
                        html: result.html
                    };
                    email.send(mailOptions)
                        .then(function (successMsg) {
                            db.setConfirmCode(user, confirmCode)
                                .catch(function (err) { // catch setConfirmCode err
                                    deferred.reject(err);
                                });
                            deferred.resolve(successMsg);
                        })
                        .catch(function (err) { // catch send err
                            deferred.reject(err);
                        })

所以我将templateVals传递给渲染调用,我试图弄清楚如何在渲染模板上显示这些信息,如下所示:

link(rel='stylesheet', href='./style.css')
|
|
p !{url}
p #{url}
p url
p templateVals.url
p #{templateVals.url}
p !{templateVals.url}

这些组合似乎都没有效果。我不确定我在这里做错了什么。谢谢你的帮助!

1 个答案:

答案 0 :(得分:0)

结束时不是代码问题,但是webstorm文件观察者将html文件放在email-templates模板目录中导致渲染失败