可以';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 = {};

可以';t将jQuery post数据发送到MVC控制器

您可以通过以下几种方式将数据发送到控制器:在这个例子中,你可以用3种方式将数据发送到控制器:

  1. Ajax.BeginForm
  2. 型号
  3. ViewModel
  4. Jquery中的Ajax
  5. FormCollection
  6. 定义输入

下载示例。

对不起,一个编写MVC控制器的人使用了错误的命名空间。现在一切都好了。谢谢你的帮助。