博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
asp.net mvc 如何在执行完某任务后返回原来页面
阅读量:4943 次
发布时间:2019-06-11

本文共 1362 字,大约阅读时间需要 4 分钟。

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

假设在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中,将原来的

 

[HttpPost]ActionResult Delete(int id){    try    {        ...        return RedirectToAction(...);    }    catch    {    }}

改为:

[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><href = "/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里边内部处理了,这个是终极做法。

 

 

点击下载免费的敏捷开发教材:《》

 

转载于:https://www.cnblogs.com/JPAORM/archive/2011/06/14/2510491.html

你可能感兴趣的文章
排序规则
查看>>
percent的用法
查看>>
Hibernate三种状态详解
查看>>
判断一个数是否是2^N次方
查看>>
js中几种实用的跨域方法原理详解
查看>>
打印图形
查看>>
《第一行代码》学习笔记7-活动Activity(5)
查看>>
ngx_http_core_module 模块
查看>>
两个常见的oracle索引
查看>>
一位有着工匠精神的博主写的关于IEnumerable接口的详细解析
查看>>
MySQL中特有的函数If函数
查看>>
安装Python3.6.2报错:zipimport.ZipImportError: can't decompress data; zlib not available
查看>>
【蓝桥杯】入门训练 Fibonacci数列
查看>>
实验十 指针2
查看>>
常见HTTP状态码
查看>>
vim 空格和换行的删除和替换
查看>>
ionic 入门学习
查看>>
[python]pickle和cPickle
查看>>
末日了,天是灰色的。
查看>>
Vuejs vm对象详解
查看>>