【发布时间】:2020-06-21 13:20:29
【问题描述】:
我是 .NET 的新手,我想打开一个模式弹出窗口,然后将此数据保存到 db 而不重新加载页面。
首先,用户需要点击一个按钮。模态是通过 ajax 加载的。用户填写表单,然后验证内容并将其发布到数据库。
这是按钮的代码:
<button class="btn btn-primary" asp-controller="Positions" asp-action="Create"
data-toggle="ajax-modal" data-target="#add-contact">Add new Positions</button>
这是控制器:
// GET: Positions/Create
public IActionResult Create()
{
return View();
}
// POST: Positions/Create
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Create([Bind("PositionId,PositionName")] Position position)
{
if (ModelState.IsValid)
{
_context.Add(position);
await _context.SaveChangesAsync();
return RedirectToAction(nameof(Index));
}
return View(position);
}
这是模型(很简单)
public class Position
{
[Key]
public int PositionId { get; set; }
public string PositionName { get; set; }
}
这是我观点的代码:
@model Models.Position
@{
ViewData["Title"] = "Create";
}
<h3>Create Position</h3>
<hr/>
<div class="modal fade" id="add-contact" tabindex="-1" role="dialog" aria-labelledby="addPositionsLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="addPositionsLabel">Add positions</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
</div>
<div class="modal-body">
<form asp-action="Create">
<input name="IsValid" type="hidden" value="@ViewData.ModelState.IsValid.ToString()" />
<div class="form-group">
<label asp-for="PositionName"></label>
<input asp-for="PositionName" class="form-control" />
<span asp-validation-for="PositionName" class="text-danger"></span>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary" data-save="modal">Save</button>
</div>
</div>
</div>
</div>
@section Scripts {
@{ await Html.RenderPartialAsync("_ValidationScriptsPartial"); }
}
如何正确打开此弹出对话框窗口,然后将填充的行保存到 db(通过 ajax)而不重新加载页面?
【问题讨论】:
标签: javascript jquery .net ajax asp.net-core