我一直在尝试让ajax在node js上工作。这是第一次使用 ajax,所以我一直在尝试使用控制台来测试它以检查它是否有效,但每次尝试时我都没有在控制台上得到响应。
这是我的代码。
<script>
function getMessage() {
var data = $("#messageselect").val()
$.ajax({
url: "/message",
type: "POST",
data: JSON.stringify(data)
dataType: 'json',
success: function(data) {
console.log(data);
}
error : function(err)
console.log("error fetching message");
});
}
</script>
服务器
app.post('/message', function(req, res) {
console.log(JSON.stringify(req.body));
Message.findOne({ 'page.message' : req.data }, function(err, message) {
if(err)
throw err;
res.send(message);
});
});
html
<form method="POST">
<select multiple="multiple" class="messageselect" onchange="getMessage()" id="messageselect">
<% if(message) { %>
<% for(i=messagecount-1;i>=0;i--) { %>
<option value="<%= message[i].page.message %>">From: <%= message[i].page.username %> Message: <%= message[i].page.messagetitle %></option>
<% } %>
<% } %>
</select><br><br><br>
</form>
最佳答案
我猜这是代码中的拼写错误之一:
var = data $("#messageselect").val()
//--^^--------------------------------worng way to assign.
<小时/>
jQuery.ajax()
需要一个对象来发送:
var data = { data : $("#messageselect").val() };
在服务器上您可以使用req.body
来获取发布的数据:
console.log(req.body.data);
注意:
为此,您需要有 body-parser
,因此请确保将其包含在上面的代码配置中。
关于javascript - 无法让 jquery AJAX 工作 Node js Express,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34493394/