我有一个表单,用于向使用Ajax的数据库提交post data
,如下所示:
function markAsRead(id) {
console.log('Triggered');
$.ajax({
type: 'POST',
url: '/admin/assessment.html',
data: id,
success: function(data) {
if (data.error) {
console.log('We had an error.');
} else if (data.success) {
console.log('Marker updated.');
}
}
})
}
(function() {
var element = document.getElementsByName('markAsRead');
for(var i = 0; i < element.length; i += 1) {
element[i].addEventListener('click', function(e) { e.preventDefault;
markAsRead(this.getAttribute('data-value'));
});
}
})();
我的页面上有多个Anchor,例如:
<a href="#" name="markAsRead" data-value="5135135">Mark As Read</a>
我只是想知道事情的Node.js
方面,我如何解析这些数据,我试过:
var id = req.body.markAsRead;
console.log('Data is ' + id);
但它只是说未定义。有关如何解析此请求数据的任何信息都很棒。谢谢! (Anchor
不在任何形式内)
答案 0 :(得分:1)
首先,您应该使用命名参数从客户端发布数据,或者使用比字符串更结构化的内容。
$.ajax({
type: 'POST',
url: '/admin/assessment.html',
data: { id: id },
success: function(data) {
if (data.error) {
console.log('We had an error.');
} else if (data.success) {
console.log('Marker updated.');
}
}
})
其次,当您解析节点端的req.body时,您正在解析作为请求正文发送的字符串,其中包含您的参数 {id:'somevalue'} 。你可以自己解析这个问题,但我猜你在节点的支持middleware stack的http.Server实现之上使用的是 express 或其他抽象。我建议使用connect bodyParser()中间件,它将req.body字符串转换为具有已发布属性的对象。这将使您在节点中的请求处理程序中可以使用 req.body.id 。