这是一个关于正确使用node-mandrill的新手问题,而且很可能是节点本身,因为我仍在努力学习它。但是,由于我已经看到许多例子直接从客户端使用mandrill的api键并因此揭示它,我想知道它在服务时究竟是如何工作但是在这一点上陷入困境:
我有一个app.js服务于公共文件夹...
app.js
var express = require('express');
var mandrill = require('node-mandrill')(API_KEY);
var app = express();
app.use(express.static('public'));
app.listen(PORT);
function sendEmail ( _name, _email, _subject, _message) {
mandrill('/messages/send', {
message: {
to: 'EMAIL',
from: [{email: _email , name: _name}],
subject: _subject,
text: _message
}
}, function(error, response){
if (error) console.log( error );
else console.log(response);
});
}
...使用客户端脚本从联系表单收集信息并在单击提交按钮时发送电子邮件。
form.js
var contactForm = document.getElementById( 'contactForm' );
new stepsForm( contactForm, {
onSubmit : function( form ) {
// send email
var _subject = 'Contact Request';
var _email = contactForm.elements['q4'].value;
var _name = contactForm.elements['q5'].value;
var _message = contactForm.elements['q6'].value;
sendEmail(_name,_email,_subject,_message);
}
} );
你能告诉我什么遗失/错了吗? 感谢。
答案 0 :(得分:0)
您无法从客户端调用后端功能。您可以使用Jquery来调用Ajax:
$(document).ready(function(){
$('#contactForm').submit(function(event) {
event.preventDefault();
var _subject = 'Contact Request';
var _email = contactForm.elements['q4'].value;
var _name = contactForm.elements['q5'].value;
var _message = contactForm.elements['q6'].value;
$.ajax({
url: '/sendEmail',
method: 'post',
contentType: 'application/json',
data: JSON.stringify({ subject: _subject, email: _email}),
success: function(res) {
}
})
})
})
在你的后端:
// some lines skipped
app.post('/sendEmail', function(req, res) {
//do your stuff
})