Параметры jquery Ajax - данные не передаются в действие MVC Controller
Я передаю два строковых параметра из jQuery ajax-вызова методу контроллера MVC, ожидая ответ json. Я вижу, что параметры заполняются на стороне клиента, но соответствующие параметры на стороне сервера равны нулю.
Вот javascript:
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "List/AddItem",
data: "{ ListID: '1', ItemName: 'test' }",
dataType: "json",
success: function(response) { alert("item added"); },
error: function(xhr, ajaxOptions, thrownError) { alert(xhr.responseText); }
});
Вот метод контроллера:
Function AddItem(ByVal ListID As String, ByVal ItemName As String) As JsonResult
'code removed for brevity
'ListID is nothing and ItemName is nothing upon arrival.
return nothing
End Function
Что я делаю неправильно?
Ответы
Ответ 1
Я пробовал:
<input id="btnTest" type="button" value="button" />
<script type="text/javascript">
$(document).ready( function() {
$('#btnTest').click( function() {
$.ajax({
type: "POST",
url: "/Login/Test",
data: { ListID: '1', ItemName: 'test' },
dataType: "json",
success: function(response) { alert(response); },
error: function(xhr, ajaxOptions, thrownError) { alert(xhr.responseText); }
});
});
});
</script>
и С#:
[HttpPost]
public ActionResult Test(string ListID, string ItemName)
{
return Content(ListID + " " + ItemName);
}
Это сработало. Удалите contentType
и установите data
без двойных кавычек.
Ответ 2
Если у вас возникли проблемы с кешированием ajax, вы можете отключить его:
$.ajaxSetup({cache: false});
Ответ 3
Вам нужно добавить → contentType: "application/json; charset = utf-8",
<script type="text/javascript">
$(document).ready( function() {
$('#btnTest').click( function() {
$.ajax({
type: "POST",
url: "/Login/Test",
data: { ListID: '1', ItemName: 'test' },
dataType: "json",
contentType: "application/json; charset=utf-8",
success: function(response) { alert(response); },
error: function(xhr, ajaxOptions, thrownError) { alert(xhr.responseText); }
});
});
});
</script>
Ответ 4
В моем случае, если я удалю contentType
, я получаю Внутреннюю ошибку сервера.
Вот что я получил после нескольких попыток:
var request = $.ajax({
type: 'POST',
url: '/ControllerName/ActionName' ,
contentType: 'application/json; charset=utf-8',
data: JSON.stringify({ projId: 1, userId:1 }), //hard-coded value used for simplicity
dataType: 'json'
});
request.done(function(msg) {
alert(msg);
});
request.fail(function (jqXHR, textStatus, errorThrown) {
alert("Request failed: " + jqXHR.responseStart +"-" + textStatus + "-" + errorThrown);
});
И это код контроллера:
public JsonResult ActionName(int projId, int userId)
{
var obj = new ClassName();
var result = obj.MethodName(projId, userId); // variable used for readability
return Json(result, JsonRequestBehavior.AllowGet);
}
Обратите внимание, что случай ASP.NET немного отличается, мы должны применить JSON.stringify()
к данным, указанным в обновлении этого ответа.