如果有条件,在JsonResult中返回一个模态确认框

Return a modal confirmation box in a JsonResult from controller if a condition

本文关键字:一个 模态 确认 有条件 JsonResult 返回 如果      更新时间:2023-09-26

大家好,我有以下情况:我有一个视图,其中我有一个保存按钮,序列化表单并通过Ajax将其发送到控制器中的JsonResult。在这个JsonResult中,我在数据库中添加/编辑表。我的问题是,如果存在某个条件,是否可以向视图返回确认框。下面是我的代码。提前感谢:)

这是javascript在我的视图,是通过ajax发送表单数据到控制器。

<script>
    function submitForm() {
        $.ajax({
            type: 'POST',
            url: '@Url.Action("UpdateEvent", "EventCalendar")',
            data: $('#UpdateEventForm').serialize(),
            success: function (eventoId) {
                $('#modal-edit-event').modal('hide');
                $('#calendar').fullCalendar('refetchEvents');
            }
        });
    }

这是我的控制器代码,正在接收表单数据:

 public JsonResult UpdateEvent(.........)
 {
   List<Guid> usersChanged = new List<Guid>();
   .
   .
   .
   if(usersChanged.Count() > 0)
   {
    //Here is where i want to call a confirmation box
   }
   .
   .
   .
   return Json(eventId, JsonRequestBehavior.AllowGet);
}

}

这是可能的。您所要做的就是返回在模态对话框中显示所需的HTML标记。

在这里,我使用RenderRazorViewToString方法(来自Ben Lesh的回答onRender a view as a string)

public string RenderRazorViewToString(string viewName, object model)
{
    ViewData.Model = model;
    using (var sw = new StringWriter())
    {
        var viewResult = ViewEngines.Engines.FindPartialView(ControllerContext,
                                                                    viewName);
        var viewContext = new ViewContext(ControllerContext, viewResult.View,
                                        ViewData, TempData, sw);
        viewResult.View.Render(viewContext, sw);
        viewResult.ViewEngine.ReleaseView(ControllerContext, viewResult.View);
        return sw.GetStringBuilder().ToString();
    }
}

现在,您只需要根据需要调用这个方法来获取viewresult

的字符串版本
public ActionResult UpdateEvent()
{
    if (SomeConditionHere)
    {
       var modalMarkup = RenderRazorViewToString("MyModalView", null);
       return Json(new { status = "failed", data = modalMarkup },
                                                            JsonRequestBehavior.AllowGet);
    }
    return Json(new { status = "success", eventId = 123 }, JsonRequestBehavior.AllowGet);
}

假设您有一个名为MyModalView.cshtml的视图,该视图具有引导模式对话框所需的标记,如下所示

<div class="modal-content">
    <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                                   <span aria-hidden="true">&times;</span></button>
        <h4 class="modal-title" id="myModalLabel">Modal title</h4>
    </div>
    <div class="modal-body">
        <h2>Modal content</h2>
    </div>
    <div class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
        <button type="button" class="btn btn-primary">Save changes</button>
    </div>
</div>

确保ajax调用的成功事件回调方法正在检查返回的json数据,并根据status属性值,根据需要使用data/eventId。

success: function (res) {
    $("#myModal").remove();
    if (res.status === "failed") {
        $('<div id="myModal" class="modal fade"><div class="modal-dialog" role="document">'
                +res.data 
                +'</div></div>')
            .modal();
    } else {
        alert("eventId is : "+ res.eventId);
    }
}