Я пытаюсь создать частичное представление, которое будет отображаться в модальном режиме при нажатии кнопки. Если есть другой подход, который работает лучше для этого, я открыт для него - модал работал отлично, пока я не добавил List
к основному виду. Если есть способ вернуть обратно список и форму публикации единственной сущности, которая может работать для моего сценария. Прямо сейчас код, который у меня есть, работает до некоторой степени, однако вам нужно дважды нажать кнопку Add Service
, чтобы появился модальный режим, и когда единственный способ избавиться от него - отправить, оба X верхняя часть и кнопка закрытия не работают.
основной вид
@model List<ServicesPosting>
<div>
<button id="addService" onclick="OpenModal()">Add Service</button>
</div>
<div id="AddServiceForm"></div>
<script type="text/javascript">
function OpenModal() {
var url = '@Url.Action("AddServiceModal", "Services")';
$('#AddServiceForm').load(url);
$('#serviceModal').modal();
}
</script>
Контроллер
public class ServicesController : Controller
{
// GET: Services
public ActionResult Index()
{
List<ServicesPosting> postings = DataAccess.GetAllPostings();
return View(postings);
}
[HttpGet]
public ActionResult AddServiceModal()
{
return PartialView("~/Views/Services/AddNewService.cshtml");
}
}
частичный вид
@model ServicesPosting
<!-- Modal -->
<div class="modal fade" id="serviceModal" tabindex="-1" role="dialog" aria-labelledby="serviceModalLabel">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">×</span>
</button>
<h4 class="modal-title" id="serviceModalLabel">Add New Service</h4>
</div>
<div class="modal-body">
@using (Html.BeginForm("Index", "Services"))
{
// TODO: validate up front
<div class="row">
Service Title : @Html.TextBoxFor(x => x.ServiceTitle)
</div>
<div class="row">
ServiceDescription : @Html.TextAreaFor(x => x.ServiceDescription)
</div>
<div class="modal-footer">
<button type="button" class="btn" data-dismiss="modal">Close</button>
<button type="submit" class="btn btn-primary">Save Changes</button>
</div>
}
</div>
</div>
</div>
</div>