ASP.NET后台代码方式识别页面“按钮点击”和浏览器F5“刷新”事件
最近有一些朋友向我咨询有关页面刷新与按钮的事情,简单的说就是当按钮事件发生后,用户又按“F5”或刷新按钮刷新了页面,这样按钮中的事件就会重复执行,这不是我们希望看到的。
以前也有一些解决方案,其中有些是Javascript完成的,有些是后台代码完成的。前者不是今天讨论重点,今天主要向大家介绍一种C#完成的“刷新”监控方法,当用户使用“F5”或浏览器的“刷新”按钮时,代码就会检测到,并以bool值方式返回。这是从以前一个老大的类库中分离出来的,老大的名字忘了。。。,去掉了无关的内容,只保留检测刷新的模块,这样干净些。
“刷新”是怎么回事?
刷新是通过浏览器重复向服务器提交最新请求来完成的,当用户点击某个按钮后,浏览器会将按钮状态量缓存,这时如果用户再使用“刷新”功能,浏览器就会机械的提交包含按钮状态量的“最新请求”,而浏览器不会为“刷新”事件提供任何通知(事实上,浏览器只对“转到”事件提供了通知),所以服务器端无法区分刷新与一般提交事件,这样服务器在收到请求后,自然会重复执行按钮事件了。
识别“刷新”原理:
使用一个上下文唯一的票据号,该票据号随页面提交或回发而递增,每当用户与服务器端交互时,代码会提取上次的票据号码并与当前票据号码比较,如果当前票据大于上次的票据,则是提交或回发,否则则识别为刷新。 这种方式会用到HttpMoudel,并在其中操作Session。
使用方法:
1、引入dll
打包下载
2.修改web.config,在<httpModules> </httpModules>添加以下item:
其中“MsdnModule”是一个名字, “Msdn.RefreshModule”是“Msdn”下的“RefreshModule”类型,“MsdnExt”是程序集的名字
3.引入命名空间 using Msdn; 并修改页面类继承Msdn.Page
4.使用代码
源代码下载:
打包下载
注意:
该方法最好在按钮事件对应的方法中使用,否则可能会失效。
以前也有一些解决方案,其中有些是Javascript完成的,有些是后台代码完成的。前者不是今天讨论重点,今天主要向大家介绍一种C#完成的“刷新”监控方法,当用户使用“F5”或浏览器的“刷新”按钮时,代码就会检测到,并以bool值方式返回。这是从以前一个老大的类库中分离出来的,老大的名字忘了。。。,去掉了无关的内容,只保留检测刷新的模块,这样干净些。
“刷新”是怎么回事?
刷新是通过浏览器重复向服务器提交最新请求来完成的,当用户点击某个按钮后,浏览器会将按钮状态量缓存,这时如果用户再使用“刷新”功能,浏览器就会机械的提交包含按钮状态量的“最新请求”,而浏览器不会为“刷新”事件提供任何通知(事实上,浏览器只对“转到”事件提供了通知),所以服务器端无法区分刷新与一般提交事件,这样服务器在收到请求后,自然会重复执行按钮事件了。
识别“刷新”原理:
使用一个上下文唯一的票据号,该票据号随页面提交或回发而递增,每当用户与服务器端交互时,代码会提取上次的票据号码并与当前票据号码比较,如果当前票据大于上次的票据,则是提交或回发,否则则识别为刷新。 这种方式会用到HttpMoudel,并在其中操作Session。
使用方法:
1、引入dll
打包下载
2.修改web.config,在<httpModules> </httpModules>添加以下item:
<add name="MsdnModule" type="Msdn.RefreshModule, MsdnExt"/>
其中“MsdnModule”是一个名字, “Msdn.RefreshModule”是“Msdn”下的“RefreshModule”类型,“MsdnExt”是程序集的名字
3.引入命名空间 using Msdn; 并修改页面类继承Msdn.Page
4.使用代码
C#复制代码
- protected void Button1_Click(object sender, EventArgs e){
- if (!IsPageRefresh)
- Response.Write("按钮事件");
- else
- Response.Write("页面刷新");
- TrackRefreshState();
- }
打包下载
注意:
该方法最好在按钮事件对应的方法中使用,否则可能会失效。
上一篇:Coolite表单布局控件FormLayout与FromPanel
下一篇:OutputCache造成页面响应内容类型为text/vnd.wap.wml的问题
全部评论:
申明:本站部分文章来自网络,由于各种原因对文章的来源无从考究,如果您是“
ASP.NET后台代码方式识别页面“按钮点击”和浏览器F5“刷新”事件
”的原作者,若侵犯您的版权,请与我联系!在此请您原谅我的幼稚和无知!联系方法:email:ahuinan@21cn.com QQ:106494262
感谢以下网友对网站提出的建议:
1、感谢“蓝树叶kiss”网友发现一个评论漏洞。(2009-2-28)
2、感谢“陈臣”对程序优化和seo方面的建议。(2009-3-18)
感谢以下网友对网站提出的建议:
1、感谢“蓝树叶kiss”网友发现一个评论漏洞。(2009-2-28)
2、感谢“陈臣”对程序优化和seo方面的建议。(2009-3-18)
文章档案
- 作者:缘清(aicken)
- 来源:缘清(aicken)'s blog
- 日期:2010-2-7 22:49:00
- 点击:395
网友投票(您觉得这篇文章怎样?)
请稍侯......
请稍侯......
文章阅读排行
随便看看
最新评论
- 不錯的東東,
打包demoupload.asp,js部分尾多了一個逗號
有空多交流:QQ 37787553 - 不錯的東東,
打包demoupload.asp,js部分尾多了一個逗號
有空多交流:QQ 37787553 - 站长 好!
- 网站不错<br>不知道URl是用什么生成的?
- update A
set A.OriginSalary=A.OriginSalary+B.AddSalary
from dbo.OriginSalary as A left join dbo.AddSalary as B on A.O_ID=B.O_ID - update A
set A.OriginSalary=A.OriginSalary+B.AddSalary
from dbo.OriginSalary as A left join dbo.AddSalary as B on A.O_ID=B.O_ID - 例子举得不好,为什么不直接用update解决呢?
update set A.OriginSalary=A.OriginSalary+B.AddSalary
from dbo.OriginSalary as A left join dbo.AddSalary as B on A.O_ID=B.O_ID - 例子举得不好,为什么不直接用update解决呢?
update set A.OriginSalary=A.OriginSalary+B.AddSalary
from dbo.OriginSalary as A left join dbo.AddSalary as B on A.O_ID=B.O_ID - 恭喜站长改进 支持
- 改版了? 牛叉
- 网站不错^-^ 多多向站长学习
- 212
- 啊 是