很多时候删除某个元素后,我们都希望回到原来的页面,如何实现呢?

假设在XController的index.cshtml(或aspx)中有:

[html] view plain copy print ?
  1. <a><hrefhref = "/area/XController/delete?id=10">


删除
,为了让删除后回到index页面,可以使用:

[html] view plain copy print ?
  1. <a><hrefhref = "/area/XController/delete?id=10&backUrl=" + @Request.Url.ToString()>


且在XController.cs中,将原来的

   
   
   
   
  1.  
  2. [csharp] view plaincopy  
  3. 01.<pre class="csharp" name="code">[HttpPost]    
  4. 02.ActionResult Delete(int id)    
  5. 03.{    
  6. 04.    try    
  7. 05.    {    
  8. 06.        ...    
  9. 07.        return RedirectToAction(...);    
  10. 08.    }    
  11. 09.    catch    
  12. 10.    {    
  13. 11.    }    
  14. 12.}pre><br>    
改为:
   
   
   
   
  1.  
  2. [csharp] view plaincopy  
  3. 01.[HttpPost]    
  4. 02.    
  5. 03.ActionResult Delete(int id, string backUrl)    
  6. 04.{    
  7. 05.    try    
  8. 06.    {    
  9. 07.        ...    
  10. 08.        return Redirect(backUrl);    
  11. 09.    }    
  12. 10.    catch    
  13. 11.    {    
  14. 12.    }    
  15. 13.}    

Request.Url包含了所有的地址信息(包括参数),它是一个Uri类型而非String,因此可以进行很多其他额外操作(如只要地址/服务器/查询参数等),详情可上网搜索。

没有试过"/Area/Controller/Action/id"怎么弄,应该大致相仿。

 

2011-08-18补充:当backUrl里边有“&”的时候(要返回的地方有多个参数),直接这样写会出错,必须:

 

   
   
   
   
  1.  
  2. [html] view plaincopy  
  3. 01.<a><hrefhrefhrefhref = "/area/XController/delete?id=10&backUrl=" + @(HttpUtility.UrlEncode(Request.Url.ToString()))>    

以便对返回代码编码(把所有特殊字符全部变成%什么的,中文也一样运行)。

写多了就觉得麻烦做了个Helper:

 
    
    
    
    
  1. [csharp] view plaincopyprint?  
  2. public static partial class Helper   
  3. {   
  4. public static string ReturnUrlOf(this HtmlHelper htmlHelper, HttpRequestBase request)   
  5. {   
  6. return HttpUtility.UrlEncode(request.Url.ToString());   
  7. }   
  8. }  

在原来要写那些东西的地方写上Html.ReturnUrlOf(Request)就可以了(Request是View的一个属性,和Html一样随叫随到)。
但是没有最懒只有更懒,如果你和本人一样对
进行了封装,那么可以把接口直接封装成:

   
   
   
   
  1.  
  2. html] view plaincopy  
  3. [email protected]("x", "/SFC/Categories/Delete?rootID=" + root.ID + "&id=" + Model.ID, returnRequest: Request)    

所有Encode 和Request问题都在 Link里边内部处理了,这个是终极做法。