前几天把添加、修改功能都做了,今天开始写删除功能。删除文章既要删除文章本身同时也要在公共模型中删除对应项。
首先写从数据库中删除文章的函数。打开ArticleRepository修改Delete的函数。有上次的教训这次明白了传递的id应该是公共模型id。
/// <summary>/// 删除文章/// </summary>/// <param name="commonModelId">公共模型id</param>/// <returns></returns>public override bool Delete(int commonModelId){dbContext.CommonModels.Remove(dbContext.CommonModels.SingleOrDefault(cM => cM.CommonModelId == commonModelId));dbContext.Articles.Remove(dbContext.Articles.SingleOrDefault(a => a.CommonModelId == commonModelId));return dbContext.SaveChanges() > 0;}
很简单先在对应的公共模型删除,再删除文章,然后保存、返回。
第二步做UserDelete(int id) action。动作中先是ArticleRepository.Delete(id)进行删除并返回是否成功。然后判断请求类型:如果是Ajax方式返回是否成功的json类型;否则跳转到提示页或错误页。
/// <summary>/// 删除文章/// </summary>/// <param name="id">公共模型id</param>/// <returns></returns> [UserAuthorize]public ActionResult UserDelete(int id){bool _deleted = articleRsy.Delete(id);if (Request.IsAjaxRequest()){return Json(_deleted);}else{if (_deleted){Notice _n = new Notice { Title = "删除文章成功", Details = "您已经成功删除了该文章!", DwellTime = 5, NavigationName = "我的文章", NavigationUrl = Url.Action("UserOwn", "Article") };return RedirectToAction("UserNotice", "Prompt", _n);}else{Error _e = new Error { Title = "删除文章失败", Details = "在删除文章时发生错误", Cause = "该文章已经被删除", Solution = Server.UrlEncode("<li>返回<a href='" + Url.Action("UserOwn", "Article") + "'>我的文章</a>页面,输入正确的信息后重新操作</li><li>返回<a href='" + Url.Action("UserDefault", "Article") + "'>文章管理首页</a>。</li><li>联系网站管理员</li>") };return RedirectToAction("ManageError", "Prompt", _e);}}}
第三步开始做删除的前台。就不单独写视图,直接写在“我的文章中”。打开UserOwn.cshtml,修改删除连接的ActionLink为@Html.ActionLink("删除", "UserDelete", new { id = item.CommonModelId }, new { @class = "btnDel" })
然后写点击删除链接的js代码
<script type="text/javascript">$(".btnDel").click(function () {if (confirm("你确定要删除该文章吗?")) {var url = $(this).attr("href");$.post(url, null, function (data) {if (data) {alert("删除成功!");window.location.reload();}else {alert("删除失败!");}});}return false;}); </script>
先提示“你确定要删除该文章吗?”,如果确定则采用post方式请求删除,并返回相应结果给出相应提示。
F5 删除一下文章看。