很多时候删除某个元素后,我们都希望回到原来的页面,如何实现呢?
假设在XController的index.cshtml(或aspx)中有:
<a><href = "/area/XController/delete?id=10">
删除</a>,为了让删除后回到index页面,可以使用:
<a><href = "/area/XController/delete?id=10&backUrl=" + @Request.Url.ToString()>
且在XController.cs中,将原来的
<pre class="csharp" name="code">[HttpPost] ActionResult Delete(int id) { try { ... return RedirectToAction(...); } catch { } }</pre><br>
改为:
[HttpPost] ActionResult Delete(int id, string backUrl) { try { ... return Redirect(backUrl); } catch { } }
Request.Url包含了所有的地址信息(包括参数),它是一个Uri类型而非String,因此可以进行很多其他额外操作(如只要地址/服务器/查询参数等),详情可上网搜索。
没有试过"/Area/Controller/Action/id"怎么弄,应该大致相仿。
2011-08-18补充:当backUrl里边有“&”的时候(要返回的地方有多个参数),直接这样写会出错,必须
<a><hrefhref = "/area/XController/delete?id=10&backUrl=" + @(HttpUtility.UrlEncode(Request.Url.ToString()))>
以便对返回代码编码(把所有特殊字符全部变成%什么的,中文也一样运行)。
写多了就觉得麻烦做了个Helper:
public static partial class Helper { public static string ReturnUrlOf(this HtmlHelper htmlHelper, HttpRequestBase request) { return HttpUtility.UrlEncode(request.Url.ToString()); } }
在原来要写那些东西的地方写上Html.ReturnUrlOf(Request)就可以了(Request是View的一个属性,和Html一样随叫随到)。
但是没有最懒只有更懒,如果你和本人一样对<a>进行了封装,那么可以把接口直接封装成:
@Html.Link("x", "/SFC/Categories/Delete?rootID=" + root.ID + "&id=" + Model.ID, returnRequest: Request)
所有Encode 和Request问题都在 Link里边内部处理了,这个是终极做法。