0

这是我的GesAgence页面操作:

        public ActionResult GesAgence()
    {
        var test = new Models.J2VEntities();
        return View(test.agence);
    }

这是我的行动Deleting

        public ActionResult DeleteAg(string id)
    {
        Models.J2VEntities entity = new Models.J2VEntities();

        Models.agence model = (from p in entity.agence
                               where p.Idag == id
                               select p).SingleOrDefault();

        //Sauvgarde ds la BD
        entity.agence.DeleteObject(model);
        entity.SaveChanges();
        return View("gesAgence");
    }

所以我想知道删除后如何返回成功消息(我尝试使用 TempData 但没有成功,因为我gesAgence必须返回模型不是TempData)。

4

3 回答 3

0

您可以将成功设置为 ViewBag

  public ActionResult DeleteAg(string id)
    {
        Models.J2VEntities entity = new Models.J2VEntities();

        Models.agence model = (from p in entity.agence
                               where p.Idag == id
                               select p).SingleOrDefault();

        //Sauvgarde ds la BD
        entity.agence.DeleteObject(model);
        entity.SaveChanges();

        ViewData["Success"] = true;

        return View("gesAgence");
    }

在视野中

@if(ViewData["Success"] != null && (bool)ViewData["Success"]){
    <script>alert("Sucess!");</script>
}

这是我的观点:

    <% if(ViewData != null && ViewData["Success"] != null && (bool)ViewData["Success"]){ %>
    <script type="text/javascript"> alert("Sucess!");</script>
<% } %>
      <div class="clear">
              &nbsp;
            </div>
            <div id="main">
            <h1> Demande preinscrit</h1>
            <ul class="listing">
    <% foreach (var item in Model) { %>
                <li>
               <div class="listinfo">
                    <h3>
                      <%: Html.DisplayFor(modelItem => item.Nomag) %>
                    </h3>
                    <p>
                      <%: Html.DisplayFor(modelItem => item.Idag) %>
                    </p>
                    <span class="price"> <%: Html.DisplayFor(modelItem => item.Adrag) %> <%: Html.DisplayFor(modelItem => item.Vilag) %> <%: Html.DisplayFor(modelItem => item.Gov) %></span> <span class="media">Tel : <%: Html.DisplayFor(modelItem => item.Telag) %> |</span> <%: Html.DisplayFor(modelItem => item.Mailag) %>
                  </div>
                  <div class="listingbtns">
                    <span class="listbuttons"><%: Html.ActionLink("Bloque", "Bloque", new {id= item.Idag}) %> </span>
                    <span class="listbuttons"><%: Html.ActionLink("Supprime", "DeleteAg", new { id = item.Idag })%></span>
                  </div>
                  <div class="clear">
                    &nbsp;
                  </div>
                </li>
    <% } %>

我收到了这个错误:System.NullReferenceException: Object reference not set to an instance of an object在这条线上<% foreach (var item in Model) { %>

于 2012-04-10T11:06:26.107 回答
0

您可以使用 Ajax 从您的视图页面调用您的控制器并弹出消息,无论您的控制器返回什么,尝试这样的事情。

在您的视图页面上编写脚本。

function onDeleteAg (id) {
        var answer = confirm("Are you sure you want to delete AG ?")
        if (answer) {
            $.ajax(
                {
                    type: "Get",
                    url: '<%= Url.Action("DeleteAg","YourControllerName") %>',
                    data: { agId: id },
                    success: function (data) {                        
                        //HERE--data is the message you that your controller DeleteAg method will return after it's called. you need to do something here to display this message(data) anywhere you want to . something like below. 
                         alert(data);                          

                    },
                    error: (function () { alert("Error! Ag was not deleted." ); })
                });
        }
    };

控制器上的方法。

public string DeleteAg(string agId)
    {
       try{

        Models.J2VEntities entity = new Models.J2VEntities();

        Models.agence model = (from p in entity.agence
                               where p.Idag == id
                               select p).SingleOrDefault();

        //Sauvgarde ds la BD
        entity.agence.DeleteObject(model);
        entity.SaveChanges();
}
       catch(Exception ex)
        {
          return "AG has not been deleted successfully;
        }

        return "AG has been deleted successfully;
    }
于 2012-04-10T13:10:52.700 回答
0

您可以通过 ajax 调用此方法并返回JsonResult而不是ActionResult,通过查看结果您可以向用户显示消息。

public JsonResult DeleteAg(string id)
{
    Models.J2VEntities entity = new Models.J2VEntities();

    Models.agence model = (from p in entity.agence
                           where p.Idag == id
                           select p).SingleOrDefault();

    //Sauvgarde ds la BD
    entity.agence.DeleteObject(model);
    entity.SaveChanges();
    var json = new
            {
                success = true
            };
    return Json(json);
}
于 2012-04-10T11:02:42.143 回答