我正在尝试使用AJAX通过API执行POST请求。出于某种原因,我遇到了这个错误:“解析请求参数时出错”。
根据我的理解,当我将url属性传递给POST请求时,由于json解析而发生此错误。
我已经在互联网上阅读了各种stackoverflow帖子,似乎使用以下内容应该可以工作:
data: { todo: { user_id: userId, body: todoBody } },
datatype : 'json',
我也尝试过使用它,它不起作用
data: { "todo": { "user_id": userId, "body": todoBody } },
datatype : 'json',
我希望有人可以帮助我指导正确的方向:)
以下是完整代码:
index.html.erb
<div class='new-todo'>
<%= form_for todo, remote: true do |f| %>
<div class="form-group">
<%= f.label :body, 'Todo Item' %>
<%= f.text_area :body, rows: 4, class: 'form-control', placeholder: "Enter todo item" %>
</div>
<div class="form-group">
<%= f.submit "Create", class: 'btn btn-success', data: { user_id: current_user.id, user_token: current_user.auth_token} %>
</div>
<% end %>
</div>
Api.js
var superlist = {};
superlist.setupDeleteHandlers = function() {
$(document).ready(function(){
$('.new-todo').submit(function(event) {
var userId = $('.btn-success').attr("data-user-id");
var userToken = $('.btn-success').attr("data-user-token");
var todoBody = $('#todo_body').val();
var data = {"todo": {"user_id": userId, "body":todoBody}};
console.log("test", userId, userToken, todoBody, data);
$.ajax({
type : "POST",
url : "/api/users/"+userId+"/todos",
data: { "todo": { "user_id": userId, "body": todoBody } },
datatype : 'json',
contentType: "application/json; charset=utf-8",
beforeSend: function (xhr) {
xhr.setRequestHeader ("Authorization", userToken);
},
success : function() {
alert('Item successfully created!');
},
error : function(error) {
}
});
});
});
};
答案 0 :(得分:5)
尝试使用:
$.ajax({
type : "POST",
url : "/api/users/"+userId+"/todos",
data: JSON.stringify(data),
contentType: "application/json; charset=utf-8",
beforeSend: function (xhr) {
xhr.setRequestHeader ("Authorization", userToken);
},