【发布时间】:2020-10-26 21:10:59
【问题描述】:
这是对以下帖子的跟进: Modal Pop-Up Displaying Incorrectly When ModelState.IsValid = false Redirect
我的弹出窗口验证正确,但在处理表单数据后它没有关闭。一旦数据被加载到数据库中,我运行以下命令:
TempData["ID"] = status.IssueID;
return RedirectToAction("edit");
由于 Modal 没有关闭,因此视图数据会填充到 modal 而不是窗口中。
如果我尝试使用 return View("edit");底层页面失败,因为页面上没有模型数据。
这是我从上面引用的帖子中实现的当前代码:
<script>
$('body').on('click', '.modal-link', function () {
var actionUrl = $(this).attr('href');
$.get(actionUrl).done(function (data) {
$('body').find('.modal-content').html(data);
});
$(this).attr('data-target', '#modal-container');
$(this).attr('data-toggle', 'modal');
});
$('body').on('click', '.relative', function (e) {
e.preventDefault();
var form = $(this).parents('.modal').find('form');
var actionUrl = form.attr('action');
var dataToSend = form.serialize();
$.post(actionUrl, dataToSend).done(function (data) {
$('body').find('.modal-content').html(data);
});
})
$('body').on('click', '.close', function () {
$('body').find('#modal-container').modal('hide');
});
$('#CancelModal').on('click', function () {
return false;
});
$("form").submit(function () {
if ($('form').valid()) {
$("input").removeAttr("disabled");
}
});
</script>
这是我运行打开模式的代码:
<div id="modal-container" class="modal fade" tabindex="-1">
<div class="modal-dialog modal-lg">
<div class="modal-content">
</div>
</div>
</div>
<a href="@Url.Action("CreateEdit", new { controller = "Issue", issueid = Model.IssueData.issueId, addedit = "add" })" class="modal-link btn btn-success">Add New Status</a>
以下是我从模态提交数据时的操作:
[ValidateAntiForgeryToken]
[HttpPost]
public ActionResult CreateEdit(StatusViewModel model)
{
if (ModelState.IsValid)
{
StatusModel status = new StatusModel();
status.IssueID = model.IssueID;
status.StatusDate = DateTime.Today;
status.Status = model.Status;
status.ColorCode = model.ColorCode;
status.NextStep = model.NextStep;
if (model.addedit == "edit")
{
status.UpdatedByNTID = AppHttpContext.Current.Session.GetString("userntid").ToString();
string done = _adoSqlService.UpdateStatus(status);
}
else
{
status.EnteredByNTID = AppHttpContext.Current.Session.GetString("userntid").ToString();
string done = _adoSqlService.InsertStatus(status);
}
TempData["ID"] = status.IssueID;
return RedirectToAction("edit");
}
else
{
return PartialView("_CreateEdit", model);
}
}
在我实现链接中标识的 Javascript 代码之前,模态表单正确关闭但我无法验证。实施后,模态表单验证但模态接收重定向而不是关闭。我做错了什么
【问题讨论】:
标签: asp.net-core modal-dialog bootstrap-modal