asp.net防止刷新時(shí)重復(fù)提交(可禁用工具條刷新按鈕)
更新時(shí)間:2013年01月28日 17:07:28 作者:
前段時(shí)間遇到了需要禁用刷新的需求,f5按鈕就不說了,簡單的js就能把它禁用,但是工具條上的刷新按鈕卻防止不了啊,不過本文介紹的一種方法卻可以解決此問題,感興趣的朋友可以了解下啊,希望本文對(duì)你有所幫助
前段時(shí)間遇到了需要禁用刷新的需求,f5按鈕就不說了,簡單的js就能把它禁用,但是工具條上的刷新按鈕卻傻傻干不掉。
如果簡單的在刷新時(shí)重新加載畫面,通過window.location.href="url"可以很容易的實(shí)現(xiàn),但是需求是要求在刷新時(shí)什么都不做,保留畫面的狀態(tài),這下子可就復(fù)雜化了。
asp.net中分辨請(qǐng)求是重新請(qǐng)求還是通過刷新按鈕再次請(qǐng)求不是很方便,為了實(shí)現(xiàn)這個(gè)效果,試過了很多的方式,一下面的兩種為例
1.
private bool pageRefreshed = false; //頁面是否刷新提交
private bool refreshState = false; //ViewState中暫存的狀態(tài)
然后重寫Page的LoadViewState與SaveViewState方法:
protected override void LoadViewState(object savedState)
{
object[] states = (object[])savedState;
base.LoadViewState(states[0]);
refreshState = (bool)states[1];
if(Session["__PAGE_REFRESHED"] == null)
pageRefreshed = false;
else
pageRefreshed = refreshState != (bool)Session["__PAGE_REFRESHED"];
}
protected override object SaveViewState()
{
Session["__PAGE_REFRESHED"] = !refreshState;
object[] states = new object[2];
states[0] = base.SaveViewState();
states[1] = !refreshState;
return states;
}
private void Button1_Click(object sender, EventArgs e)
{
if (pageRefreshed )
{
label.Text="this is refreshed function";
}
else
{
label.Text="this is new request function";
}
}
這種方法雖然能夠?qū)崿F(xiàn),但是在某些請(qǐng)款下不適應(yīng)。如果畫面上同時(shí)存在文本框和按鈕式,設(shè)置按鈕的autopostback="True"時(shí),在修改完文本框的值,直接點(diǎn)擊按鈕(在文本框沒有失去焦點(diǎn)時(shí),直接點(diǎn)擊按鈕),這時(shí)的執(zhí)行順序是textchanged→textchanged→buttonclick,在第一次textchanged時(shí),就把狀態(tài)已經(jīng)變成了true,按鈕的不能執(zhí)行。
2.codeproject找到了另外一種解決方法
這種方式能夠準(zhǔn)確的判斷是否是通過瀏覽器的刷新按鈕進(jìn)行的請(qǐng)求,而且使用起來也非常簡單!
1.引用dll,修改配置文件
在配置文件中添加modules
<system.web>
<httpModules>
<add name="RefreshModule"
type="RefreshModule.Module, RefreshModule"/>
</httpModules>
</system.web>
PS:wbapplication的情況下需要改成在system.webServer的modules的節(jié)點(diǎn)下追加modules
2.定義刷新時(shí)的行為
[Refresh()]
public partial class Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if(IsPostBack && !RefereshHelper.IsPageRefreshed)
{
// do some work with the submitted date
}
else
{
// do some work when the page is loaded with the GET method
}
}
}
RefereshHelper.IsPageRefreshed這個(gè)參數(shù)就是用來判斷是否是通過瀏覽器的書刷新按鈕進(jìn)行的請(qǐng)求。其他的行為行為控制參照原文。PS:codeproject真是個(gè)不過的地方,很多問題都是通過它來解決的其他的方式不一一列舉,列舉的第二種方式可以說簡單易用,所有的實(shí)現(xiàn)都已經(jīng)為我們封裝好了,只需要簡單的調(diào)用。
如果簡單的在刷新時(shí)重新加載畫面,通過window.location.href="url"可以很容易的實(shí)現(xiàn),但是需求是要求在刷新時(shí)什么都不做,保留畫面的狀態(tài),這下子可就復(fù)雜化了。
asp.net中分辨請(qǐng)求是重新請(qǐng)求還是通過刷新按鈕再次請(qǐng)求不是很方便,為了實(shí)現(xiàn)這個(gè)效果,試過了很多的方式,一下面的兩種為例
1.
復(fù)制代碼 代碼如下:
private bool pageRefreshed = false; //頁面是否刷新提交
private bool refreshState = false; //ViewState中暫存的狀態(tài)
然后重寫Page的LoadViewState與SaveViewState方法:
復(fù)制代碼 代碼如下:
protected override void LoadViewState(object savedState)
{
object[] states = (object[])savedState;
base.LoadViewState(states[0]);
refreshState = (bool)states[1];
if(Session["__PAGE_REFRESHED"] == null)
pageRefreshed = false;
else
pageRefreshed = refreshState != (bool)Session["__PAGE_REFRESHED"];
}
protected override object SaveViewState()
{
Session["__PAGE_REFRESHED"] = !refreshState;
object[] states = new object[2];
states[0] = base.SaveViewState();
states[1] = !refreshState;
return states;
}
復(fù)制代碼 代碼如下:
private void Button1_Click(object sender, EventArgs e)
{
if (pageRefreshed )
{
label.Text="this is refreshed function";
}
else
{
label.Text="this is new request function";
}
}
這種方法雖然能夠?qū)崿F(xiàn),但是在某些請(qǐng)款下不適應(yīng)。如果畫面上同時(shí)存在文本框和按鈕式,設(shè)置按鈕的autopostback="True"時(shí),在修改完文本框的值,直接點(diǎn)擊按鈕(在文本框沒有失去焦點(diǎn)時(shí),直接點(diǎn)擊按鈕),這時(shí)的執(zhí)行順序是textchanged→textchanged→buttonclick,在第一次textchanged時(shí),就把狀態(tài)已經(jīng)變成了true,按鈕的不能執(zhí)行。
2.codeproject找到了另外一種解決方法
這種方式能夠準(zhǔn)確的判斷是否是通過瀏覽器的刷新按鈕進(jìn)行的請(qǐng)求,而且使用起來也非常簡單!
1.引用dll,修改配置文件
在配置文件中添加modules
復(fù)制代碼 代碼如下:
<system.web>
<httpModules>
<add name="RefreshModule"
type="RefreshModule.Module, RefreshModule"/>
</httpModules>
</system.web>
PS:wbapplication的情況下需要改成在system.webServer的modules的節(jié)點(diǎn)下追加modules
2.定義刷新時(shí)的行為
復(fù)制代碼 代碼如下:
[Refresh()]
public partial class Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if(IsPostBack && !RefereshHelper.IsPageRefreshed)
{
// do some work with the submitted date
}
else
{
// do some work when the page is loaded with the GET method
}
}
}
RefereshHelper.IsPageRefreshed這個(gè)參數(shù)就是用來判斷是否是通過瀏覽器的書刷新按鈕進(jìn)行的請(qǐng)求。其他的行為行為控制參照原文。PS:codeproject真是個(gè)不過的地方,很多問題都是通過它來解決的其他的方式不一一列舉,列舉的第二種方式可以說簡單易用,所有的實(shí)現(xiàn)都已經(jīng)為我們封裝好了,只需要簡單的調(diào)用。
相關(guān)文章
.net生成縮略圖及水印圖片時(shí)出現(xiàn)GDI+中發(fā)生一般性錯(cuò)誤解決方法
這篇文章主要介紹了.net生成縮略圖及水印圖片時(shí)出現(xiàn)GDI+中發(fā)生一般性錯(cuò)誤解決方法 ,需要的朋友可以參考下2014-11-11Community Server專題三:HttpModule
Community Server專題三:HttpModule...2007-03-03ASP.NET對(duì)txt文件相關(guān)操作(讀取、寫入、保存)
這篇文章主要介紹了ASP.NETtxt文件相關(guān)操作,包括讀取、寫入、保存,需要的朋友可以參考下2015-09-09云服務(wù)器下搭建ASP.NET Core環(huán)境
本文給大家分享的是在云服務(wù)器上搭建ASP.NET Core環(huán)境以及成功運(yùn)行官網(wǎng)DEMO的教程,十分的細(xì)致全面,有需要的小伙伴可以參考下。2016-07-07運(yùn)行page頁面時(shí)的事件執(zhí)行順序及頁面的回發(fā)與否深度了解
page頁面時(shí)的事件執(zhí)行順序的了解對(duì)于一些.net開發(fā)者起到者尤關(guān)重要的作用;頁面的回發(fā)與否會(huì)涉及到某些事件執(zhí)行與不執(zhí)行,在本文中會(huì)詳細(xì)介紹,感興趣的朋友可以了解下2013-01-01