MVC3学习:利用mvc3+ajax实现删除记录

首先根据模板生成list视图,上面就会有一个delete的链接,但是模板自带的这种删除,需要另外再打开一个删除页,再进行删除。我们可以利用ajax来改写,实现在当前页删除。

在视图上面,将原来的

@Html.ActionLink("Delete", "Delete", new { id=item.Uid })

改为

<a href="#" name="delete" id="@item.Uid">Delete</a>

接着编写JQuery ajax

<script type="text/javascript">

    $(function () {

        $("[name='delete']").click(function () {

            if (confirm("确定要删除此记录?")) {

                var Uid = $(this).attr("id");

                var tr = $(this).parent().parent();

                $.post("delete", { id: Uid },

                function (data) {

                    if (data == "-1") {

                        alert("删除失败");

                        return false;

                    }

                    else {

                        $(tr).remove();

                        alert("删除成功");

                    }

                }

                );

            }

        });

    });

</script>

此处将参数id返回给方法delete进行处理,处理完成后将结果再返回回来。

因此,接着在控制器里面编写delete方法

     public ActionResult delete(int id)

        {

            try

            {

                if (Request.IsAjaxRequest())

                {



                    Users u = db.Users.Find(id);

                    db.Users.Remove(u);

                    int n = db.SaveChanges();

                    return Content(n.ToString());

                }

                return Content("-1");

            }

            catch

            {

                return View();

            }

        }

我用的EF code first的删除记录方法。先根据find(id)找到此行记录,然后调用remove删除。

注意此处的参数名为id,必须要和ajax里面返回的参数名id一样。要用Request.IsAjaxRequest()来判断是否使用ajax处理数据。

你可能感兴趣的:(Ajax)