ASP.Net中防止刷新自动触发事件的解决方案
程序员文章站
2023-11-24 18:40:34
使用asp.net,在刷新页面的时候会自动触发服务器端的事件。举个简单的例子,如:一个注册页面,我们填写完注册信息之后,如果按f5刷新之后,会自动触发到button事件上,...
使用asp.net,在刷新页面的时候会自动触发服务器端的事件。举个简单的例子,如:一个注册页面,我们填写完注册信息之后,如果按f5刷新之后,会自动触发到button事件上,这样就造成了又注册了一次的麻烦。
我先前的解决方案:用关键字查询,如有相同,则提示已有此用户。
但是这种方案不能在没有表识的情况下使用,他会重新提交。鉴于此,我寻找了一种新的解决方案,很庆幸,在朋友的提点下,迸发了这样的解决方案,肯定有更好的解决方案,不吝赐教。
解决思路:刷新时,捕捉keypress,让他触发其他无用的事件。
1、捕捉f5事件的javascript
window.document.onkeydown = keystroke;
function keystroke()
{
var key = event.keycode;
event.srcelement.releasecapture();
if(key == 116)
{
document.getelementbyid("button1").click();
event.keycode=0;
event.returnvalue=false;
}
}
2、aspx页面放置一个button
<asp:button id="button1" style="z-index: 102; left: 344px; position: absolute; top: 408px; width: 0px;" runat="server"
text="button"></asp:button>
3、button事件
private void button1_click(object sender, system.eventargs e)
{
response.write( "you have pressed the key f5");
}
这个“舍车保帅”的方案,能解决刷新自动触发事件的解决方案这个小问题,如果谁有更好的方案,希望告诉我一声,不胜感激!
我先前的解决方案:用关键字查询,如有相同,则提示已有此用户。
但是这种方案不能在没有表识的情况下使用,他会重新提交。鉴于此,我寻找了一种新的解决方案,很庆幸,在朋友的提点下,迸发了这样的解决方案,肯定有更好的解决方案,不吝赐教。
解决思路:刷新时,捕捉keypress,让他触发其他无用的事件。
1、捕捉f5事件的javascript
window.document.onkeydown = keystroke;
function keystroke()
{
var key = event.keycode;
event.srcelement.releasecapture();
if(key == 116)
{
document.getelementbyid("button1").click();
event.keycode=0;
event.returnvalue=false;
}
}
2、aspx页面放置一个button
<asp:button id="button1" style="z-index: 102; left: 344px; position: absolute; top: 408px; width: 0px;" runat="server"
text="button"></asp:button>
3、button事件
private void button1_click(object sender, system.eventargs e)
{
response.write( "you have pressed the key f5");
}
这个“舍车保帅”的方案,能解决刷新自动触发事件的解决方案这个小问题,如果谁有更好的方案,希望告诉我一声,不胜感激!