从控制器返回消息到ajax请求jquery

时间:2018-07-30 18:40:54

标签: javascript jquery asp.net asp.net-mvc asp.net-core

我在获取Controller响应对ajax请求的响应时遇到问题。 该请求已正确完成,但是我无法从控制器获取消息以检查它是否成功。

主题控制器代码

public JsonResult SaveSubjects(SubjectViewModel model) {
  bool success = false;
  if (ModelState.IsValid) {
    success = true;
    char[] years = model.Year.ToCharArray();

    for (int i = 0; i < years.Length; i++) {
      model.Year = years[i].ToString();
      Subject s = subjectGateway.FindById(int.Parse(model.Year), model.Title);
      if (s == null)
        addSubjectUseCaseFactory.AddSubjectUseCase().Execute(new AddSubjectRequestCreator().ToRequest(model));
      else {
        success = false;
        break;
      }
    }
  }
  return Json(new {
    success
  });
}

JQUERY代码

我在混乱的地方添加了注释行

$.ajax({
  type: "POST",
  url: '@Url.Action("SaveSubject","api/Subject")',
  data: subject,
  dataType: "html",
  success: function(subject) { // the subject gets the value "{\"success\":true}"
    debugger;
    if (subject.success) { //but here the success it says undefined.
      debugger;
      var valuesArray = new Array();
      valuesArray = selectedValue.split("");
      for (var i = 0; i < valuesArray.length; i++) {
        var select = '<select id="selectYearCell" class="form-control" width="10">' +
          '<option>5</option>' +
          '<option>6</option>' +
          '<option>7</option>' +
          '<option>8</option>' +
          '<option>9</option>' +
          '</select>';
        var row = '<tr>' +
          '<td>' + (rowIndex++) + '</td>' +
          '<td>' + title + '</td>' +
          '<td>' + valuesArray[i] + '</td>' +
          '<td>' + actions + '</td>' +
          '</tr>';

        $("#mainTable").append(row);

      }

      $("#Title").val('');
      $("#Title").removeClass("makeRed");
      $('[data-toggle="tooltip"]').tooltip();
      // $("table tbody tr").eq(index + 1).find(".add, .edit").toggle();

    } else {
      alert("Lenda ekziston");
    }
  }

});
}

2 个答案:

答案 0 :(得分:0)

您的回复是一个字符串。您应该:

  1. 在ajax请求中定义dataType和contentType(当前将其设置为dataType: "html")。
  2. 使用let data = JSON.parse(subject)解析字符串

答案 1 :(得分:0)

您应该返回:

newname = (año + mes + dia + " " + emisor + " " + total + ".xml")
copiedText.close()
rename(filename, newname)

在ajax中使条件变为这样:

return Json(success);