可以';t将jQuery post数据发送到MVC控制器
本文关键字:数据 控制器 MVC post jQuery 可以 | 更新日期: 2023-09-27 17:57:29
我尝试过在谷歌上找到的解决方案,但没有任何帮助。我的ajax功能:
$.ajax({
type: "post",
url: apiEndpoint + "/CreateExercise",
data: JSON.stringify(data),
datatype: "json",
contentType: "application/json",
success: function (result) {
console.log(result);
},
error: function (xhr, status, p3, p4) {
var err = "Error " + " " + status + " " + p3 + " " + p4;
if (xhr.responseText && xhr.responseText[0] === "{") {
err = JSON.parse(xhr.responseText).Message;
}
console.log(err);
}
});
MVC控制器:
public ActionResult CreateExercise(string sessionId, Exercise ExerciseCreateInfo)
我想要发送的数据:
data.sessionId = sessionId;
data.ExerciseCreateInfo = {};
data.ExerciseCreateInfo.IsVisible = true;
data.ExerciseCreateInfo.SimilarityNorm = $("#numSimilarityScore").val();
data.ExerciseCreateInfo.TypeId = $("#selectTaskType option:selected").val();
data.ExerciseCreateInfo.Name = $("#textTaskName").val();
data.ExerciseCreateInfo.Difficulty = $("#numDifficulty").val();
data.ExerciseCreateInfo.MarkPoints = $("#numPoints").val();
data.ExerciseCreateInfo.Question = tinyMCE.get("editorTask").getContent();
data.ExerciseCreateInfo.Hint = tinyMCE.get("editorHint").getContent();
data.ExerciseCreateInfo.Explanation = tinyMCE.get("editorExpenation").getContent();
data.ExerciseCreateInfo.Fields = {};
您可以通过以下几种方式将数据发送到控制器:在这个例子中,你可以用3种方式将数据发送到控制器:
- Ajax.BeginForm
- 型号
- ViewModel
- Jquery中的Ajax
- FormCollection
- 定义输入
下载示例。
对不起,一个编写MVC控制器的人使用了错误的命名空间。现在一切都好了。谢谢你的帮助。