zoukankan      html  css  js  c++  java
  • asp.net mvc 如何在执行完某任务后返回原来页面

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

    假设在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里边内部处理了,这个是终极做法。

    学习交流群:364976091
  • 相关阅读:
    C# 中的类型转换
    Structured Query Language 入门 oracle
    C# 模板代碼的總結
    .net 頁面通過C#控件綁定時間格式的方法
    醫務室系統報表中使用的一個使用遊標的自定義方法 sqlserver
    vi 编译器的退出
    和为s的数字
    两个链表的第一个公共节点
    某数字在排序数组中出现的次数
    二叉搜索树的第k个节点
  • 原文地址:https://www.cnblogs.com/firstcsharp/p/2936560.html
Copyright © 2011-2022 走看看