Я удаляю строку в своей веб-сетке и перенаправляюсь на свой индекс GET, как обычно, после удаления. Однако, как и ожидалось, в моем представлении старая удаленная строка все еще находится в сетке. Я знаю, что это сделано по дизайну, и я должен иметь возможность установить Modelstate для очистки или удалить элемент по отдельности, чтобы добиться этого:
ModelState.Remove("id");
Or
foreach (var key in ModelState.Keys.Where(m => m.StartsWith("id")).ToList())
ModelState.Remove(key);
Or
ModelState.Remove("Applicant.ApplicantId");
Или даже :
ModelState.Clear()
Однако ни один из них не работает для меня.
Вот мой метод удаления (упрощенная обработка всех ошибок и удаление ненужного кода)
public ActionResult DeleteApplicant(int id)
{
var q =
(from a in context.Applicants
where a.ApplicantId == id
select a).Single<Applicant>();
q.ApplicantDocuments.ToList().ForEach(r => context.ApplicantDocuments.Remove(r));
context.Applicants.Remove(q);
context.SaveChanges();
foreach (var key in ModelState.Keys.Where(m => m.StartsWith("id")).ToList())
ModelState.Remove(key);
TempData["SuccessMessage"] = "Successfully deleted row.";
return RedirectToAction("Index");
}
И вот мой вызов моего метода удаления из представления:
, grid.Column(format: (item) => @Html.ActionLink("Delete", "DeleteApplicant",
new { id = item.ApplicantId }, new { @class = "delete-link" }), style: "DeleteButton")
Я просмотрел различные сообщения о stackoverflow и т. д., но ни один из них, похоже, не решает мою проблему: after-model-submit">MVC 3 Представление не обновляется после отправки модели
Я также пытался перенаправить действие Index через jquery и вызвать действие контроллера удаления с помощью ajaxOptions , но это тоже не сработало.
, grid.Column(format: (item) => @Ajax.ActionLink("Delete", "DeleteApplicant",
new { id = item.ApplicantId },
new AjaxOptions { HttpMethod = "GET" , OnSuccess= "reloadGrid" }))
И добавляем небольшой скрипт для вызова домашнего индекса:
function reloadGrid() {
var pathArray = window.location.pathname.split('/');
var segment_1 = pathArray[1];
var newURL = window.location.protocol + "//" + window.location.host + "/" + segment_1 + "/Home/Index";
$.ajax(
{
type: "GET",
url: newURL,
data: "{}",
cache: false,
dataType: "html",
success: function (data)
{ $().html(data); }
})
}
Я явно делаю что-то не так. Есть ли другой способ принудительно обновить страницу по-другому, или кто-нибудь может заметить что-то явно неправильное в моем текущем подходе. Заранее спасибо.
Примечание. У меня есть разметка веб-сетки в представлении «Индекс», а не в отдельном частичном представлении, но я не думаю, что это должно быть причиной этого?
Обновление :
Вот метод GET по запросу: (для контекста объект фильтров используется, когда нажимается кнопка поиска и страница отправляется обратно, фильтры не применяются при начальной загрузке страницы)
public ActionResult Index(string page)
{
/////Peform paging initiation
int pageIndex = 0;
if (!string.IsNullOrEmpty(page))
{
pageIndex = int.Parse(page) - 1;
}
////initialize total record count and filter results object
int totalRecordCount = 0;
var filters = new ApplicantSearchFilter();
////Perform search with paging
var applicants = this.GetApplicantsPaging(filters ,pageIndex, out totalRecordCount);
////Return view type
var data = new ApplicantViewModel()
{
Filters =filters ,
TotalRecordCount = totalRecordCount,
ApplicantReportLists = applicants,
PageIndex = pageIndex,
};
////return Index view passing data result to build it
return this.View("Index", data);
}
}