Сохранение изменений в БД MVC - PullRequest
0 голосов
/ 27 ноября 2018

У меня проблема при попытке сохранить некоторые данные в базе данных.Я вижу, как идентификатор и дата возвращают мне соответствующие значения в функции JS ... Однако параметр для функции Process внутри класса контроллера остается нулевым.Я не знаю, почему это происходит.Есть запрос linq, который также включен в Hello Model, но я не включил его, потому что в этом нет необходимости.

Модель:

 public class Hello
    {
        List<string> Ids { get; set; }

        List<string> Dates { get; set; }
    }

Контроллер:

   [HttpPost]
    public ActionResult Process(string ids, string dates) 
    {
        Hello model = new Hello();
        if (ModelState.IsValid)
        {

            using (db = new DB())
            {

                rp = new RequestProcess();
                //var c = rp.getHello(model, dates);
                var c = rp.getStuff();

                if (c != null)
                {
                    foreach (var i in c)
                    {
                        if (i != null)
                        {
                            ids = i.ID;
                            dates = i.Date.ToString();
                        }
                        db.SaveChanges();
                    }

                }

            }
            ViewBag.Message = "Success";
            return View(model);
        }
        else
        {
            ViewBag.Message = "Failed";
            return View(model);
        }
    }

Вид:

  <td><input class="id" type="checkbox" id=@item.ID /></td>
  <td>@Html.DisplayFor(x => @item.ID)</td>
  <td><input class="date" id=date@item.ID type="text" value='@item.Date'/></td>

  $(document).ready(function () {
        var ids = "";
        var dates = "";
        $("#btnSubmit").bind("click", function () {
            createUpdateArrays();
            var url = "/Sample/Process";
            $.ajax({
                type: "POST",
                url: url,
                data: { ids: ids, dates: dates },
                contentType: 'application/json; charset=utf-8',
                success: function (success) {
                    if (success === true) {
                        alert("HERE WE ARE");
                    }
                    else {
                        alert("eror");
                    }
                }
            });
            ids = "";
            dates = "";
        });
        function createUpdateArrays() {
            var i = 0;
            $('input.remedy-id:checkbox').each(function () {
                if ($(this).is(':checked')) {
                    var rid = $(this).attr("id");
                    $('.planned-date').each(function () {
                        var did = $(this).attr("id");
                        if (did === rid) {
                            var date = $(this).val();
                            ids += rid + ",";
                            dates += date + ",";
                        }
                    });
                };
            });
        };

Любая помощь будет оценена!

Ответы [ 2 ]

0 голосов
/ 27 ноября 2018

В вашем коде есть несколько проблем:

1) Вы передаете строку JSON, содержащую свойства viewmodel, необходимо установить опцию contentType: 'application/json; charset=utf-8' в обратном вызове AJAX, чтобы механизм связывания модели распознал ее как параметр viewmodel.

2) return View() не применимо для ответа AJAX, вместо этого используйте return PartialView() и поставьте html(), чтобы отобразить ответ в целевом элементе.

Следовательно, вы должны использовать настройку AJAX какниже:

$.ajax({
    type: "POST",
    url: url,
    data: JSON.stringify(list),
    contentType: 'application/json; charset=utf-8',
    success: function (result) {
        $('#targetElement').html(result);
    },
    error: function (xhr, status, err) {
        // error handling
    }
});

Действие контроллера

[HttpPost]
public ActionResult Process(Hello model) 
{
    if (ModelState.IsValid)
    {
        using (db = new DB())
        {
            // save data
        }
        ViewBag.Message = "Success";
        return PartialView("_PartialViewName", model);
    }
    else
    {
        ViewBag.Message = "Failed";
        return PartialView("_PartialViewName", model);
    }
}

Помните, что обратный вызов AJAX предназначен для обновления определенного элемента HTML без перезагрузки всей страницы просмотра.Если вы хотите перезагрузить страницу с отправленными результатами, используйте вместо этого обычную форму отправки (с Html.BeginForm()).

0 голосов
/ 27 ноября 2018

Я думаю, вам нужно contentType: 'application/json' в вашем $.ajax({});

$.ajax({
    type: "POST",
    url: url,
    data: JSON.stringify(list),
    contentType: 'application/json'
});

Также попробуйте добавить [FromBody]Hello model в действие вашего контроллера.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...