本文英文原版及代碼下載:
http://mattberseth.com/blog/2007/08/using_the_ajax_timer_control_a.html
將Timer控件用作UpdatePanel的觸發器
ASP.NET AJAX Timer概述
ASP.NET AJAX Timer控件每隔特定的時間間隔執行一次頁面回傳,它有一個 Interval屬性來定義時間間隔.當“到點”時就在服務器端觸發Timer的Tick事件. 如果你希望整個頁面回傳(full postback)的話,你只需將Timer控件放在頁面上,就像其它控件一樣。但如果你希望Timer觸發局部回傳,你有2種選擇: 1.將Timer控件放在UpdatePanel控件里 2.將Timer控件放在UpdatePanel控件外,再明白地將其注冊為一個AsyncPostBackTrigger,另外,可以在Timer的Tick事件處理器里修改Timer屬性(主要是Enabled 和 Elapsed),如果有必要的話你可以在運行的時候修改這些值.把Timer添加到頁面后,我們還要考慮使用Timer的一些其它的事情.
AJAX Timer Considerations
1.把Timer控件放在UpdatePanel的里面或者外面時,其行為稍有不同。
Timer控件放在頁面的什么地方將決定Elapsed值是如何計算的.如果 Timer放置在UpdatePanel外,當一個局部回傳執行時它繼續運行。所 以,假如Elapsed設置為5秒,而局部回傳執行了3秒,那么當局部回傳執行完畢2秒后就會觸發timer控件;而當Timer控件放置在一個UpdatePanel內部時,當回傳執行時Timer就停止運行,直到回傳執行完畢后才運行.
2.將Elapsed屬性的值設置的足夠大,以便Tick事件處理器有足夠的事件完成執行.
由于放置在UpdatePanel控件外的Timer控件在局部回傳處于執行狀態時仍在運行,如果Timer控件“到點”了而局部回傳還沒有執行完畢,那么當前的執行請求將會被取消而執行一個新的請求.這是你所不愿看到的.
3.當不再需要Timer時將其關閉
Timer控件將一直運行直到用戶導航到其它頁面或通過編程的方式將其Enabled屬性設置為'false'.如果你有辦法確定不再需要Timer控件了,將其關閉即可.如上圖,當所有操作的狀態為'Complete'時,我們用不著再使用Timer了.
Implementation(執行)
下面是UpdatePanel的聲明代碼,注意它包含了GridView和Timer控件:
<asp:UpdatePanel runat="server" UpdateMode="Conditional">
<ContentTemplate>
<%--Typical GridView--%>
<asp:GridView
ID="gvOperations" runat="server"
GridLines="None" Width="100%"
AllowSorting="true" DataSourceID="odsOperations"
OnRowDataBound="GvOperations_RowDataBound">
<AlternatingRowStyle BackColor="aliceBlue" />
<HeaderStyle HorizontalAlign="Left" />
</asp:GridView>
<%--The Timer that causes the partial postback--%>
<asp:Timer runat="server" Interval="1500" OnTick="Timer_Tick" />
</ContentTemplate>
</asp:UpdatePanel>
下面是Timer的OnTick事件處理器,它依照Waiting -> Running -> Complete的狀態調用UpdateStatus.特別的我們還可以調用DataBind對GridView進行重新綁定以查看最新的情況.
private void Timer_Tick(object sender, EventArgs args)
{
// update the data (only here for demo purposes)
if (DateTime.Now.Millisecond % 2 == 0)
{
UpdateStatus("Waiting", "Running");
}
if (DateTime.Now.Millisecond % 3 == 0)
{
UpdateStatus("Running", "Complete");
}
// refresh the grid
this.gvOperations.DataBind();
}
就是這樣的,祝編程愉快!
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
