Загрузка результата ajax в макет

На странице макета ядра Asp.NET я пытаюсь загрузить результат сообщения AJAX. Статус в порядке, но появляется ошибка:

_Layout.cshtml

<div id = "MainContentDiv">
  @RenderBody()
</div>
$.ajax({
  type: 'POST',
  url: '/Something/LoadView',
  dataType: 'json',
  contentType: 'application/json',
  data: JSON.stringify({ ... }),
  error: function (result) {
    console.info("error");
    console.info(result);
  },
  success: function (result) {
    $("#MainContentDiv").html(result);
  }
[HttpPost]
public ActionResult LoadView([FromBody] NodeData model)
{
  string action= "Index";
  switch(model.NodeType)
  {
    case StringConstants.something:
      action = "GData";
      break;
    // ...
  }  
  return RedirectToAction(action, "Some", model);
}

public PartialViewResult GData(NodeData model)
{
  // ... 
  return PartialView("_GroupsData", group);
} 

Ответ

Загрузка результата ajax в макет

Вы говорите, что обработчик error выполняется, несмотря на то, что код состояния ответа равен 200?

Rory McCrossan 28.03.2019 13:36

@RoryMcCrossan Да, верно.

John 28.03.2019 13:37

Я сомневаюсь, что это так, иначе это ошибка массивный в jQuery. Вы уверены, что видите ответ на тот же вызов AJAX? При каком событии вы делаете этот запрос AJAX?

Rory McCrossan 28.03.2019 13:38

@RoryMcCrossan Да, я перепроверил.

John 28.03.2019 13:42

Ваш метод возвращает ActionResult, пожалуйста, измените тип возвращаемого значения или измените метод AJAX

ahmeticat 28.03.2019 13:43

@ahmeticat Ajax вызывает метод, который вызывает другой метод, как я показал в коде. Пожалуйста, дайте мне знать, что нужно изменить.

John 28.03.2019 13:44

@RoryMcCrossan В событии выбранного узла дерева я делаю этот запрос Ajax.

John 28.03.2019 13:57

Что говорит responseText?

TSmith 28.03.2019 15:10

@TSmith Я могу получить HTML-код частичного представления в responseText

John 29.03.2019 06:41

@TSmith Я могу получить HTML-код частичного представления в responseText

John 29.03.2019 06:41
Как конвертировать HTML в PDF с помощью jsPDF
Как конвертировать HTML в PDF с помощью jsPDF
В этой статье мы рассмотрим, как конвертировать HTML в PDF с помощью jsPDF. Здесь мы узнаем, как конвертировать HTML в PDF с помощью javascript.
0
10
393
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Во-первых, создайте функцию, которая анализирует ActionResult в string

public string RenderRazorViewToString(string viewName, object model)
{
  ViewData.Model = model;
  using (var sw = new StringWriter())
  {
    var viewResult = ViewEngines.Engines.FindPartialView(ControllerContext,
                                                             viewName);
    var viewContext = new ViewContext(ControllerContext, viewResult.View,
                                 ViewData, TempData, sw);
    viewResult.View.Render(viewContext, sw);
    viewResult.ViewEngine.ReleaseView(ControllerContext, viewResult.View);
    return sw.GetStringBuilder().ToString();
  }
}

и return Json(RenderRazorViewToString(action,model), JsonRequestBehavior.AllowGet)

вместо return RedirectToAction(action, "Some", model)

ОБНОВИТЬ : обновление для .NET Core.

Просто измените return RedirectToAction(action, "Some", model) на view.Render("Some/"+action, model);

Я использую ядро ​​​​Asp.NET 2.2 и не могу решить проблемы с пространством имен.

John 28.03.2019 14:22

Найдена основная версия по адресу: stackoverflow.com/questions/32558941/…

John 29.03.2019 06:59

было бы здорово, если бы вы могли соответствующим образом отредактировать свой ответ.

John 29.03.2019 07:05

к сожалению, я не смог заставить работать даже базовую версию.

John 29.03.2019 07:42
Ответ принят как подходящий

dataType вы говорите jQuery, какой ответ ожидать.

Поскольку вы возвращаете результат html вместо json с сервера, попробуйте удалить dataType: 'json' напрямую в вашем ajax. См. тип данных ajax

$.ajax({
  type: 'POST',
  url: '/Something/LoadView',
  //dataType: 'json',
  contentType: 'application/json',
  data: JSON.stringify({ ... }),
  error: function (result) {
    console.info("error");
    console.info(result);
  },
  success: function (result) {
    $("#MainContentDiv").html(result);
  }
});

Другие вопросы по теме