您好,登錄后才能下訂單哦!
這篇文章給大家介紹ASP.NET編程如何實現彈窗報警提示,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
ASP.NET編程之實現彈窗報警提示的前言,在web應用中,比如OA中,經常要用到一些提示,比如EMAIL到達了,就做個象MSN那樣的提示框,彈出給用戶提示,然后再關閉。在asp.net 2.0的ajax中,這個現在不難做到了,剛好看到老外的一篇文章,講解到,下面小結
比如有個數據庫表,是存放EMAIL的,當數據庫表中的EMAIL一有的時候,就提示用戶,首先簡單寫一個WEBSERVICE如下
以下為引用的內容:
[ScriptService] public class InboxService : System.Web.Services.WebService { [WebMethod] public int GetLatestNumberOfEmails() { int numberOfEmails = 0; using (SqlConnection conn = new SqlConnection(WebConfigurationManager.ConnectionStrings[0].ConnectionString)) { using (SqlCommand cmd = new SqlCommand("GetLatestNumberOfEmails", conn)) { cmd.CommandType = CommandType.StoredProcedure; conn.Open(); numberOfEmails = (int)cmd.ExecuteScalar(); } } return numberOfEmails; } }
這里要注意要在客戶端通過AJAX調用WEBSERICE,要加上[ScriptService]
ASP.NET編程之實現彈窗報警提示在default.aspx中,首先加入一個updateprogress控件,如下
以下為引用的內容:
﹤asp:UpdateProgress DynamicLayout="False" ID="UpdateProgress1" runat="server"﹥ ﹤ProgressTemplate﹥ ﹤div id="modal" class="modal"﹥ ﹤div class="modalTop"﹥ ﹤div class="modalTitle"﹥My Inbox﹤/div﹥ ﹤span style="CURSOR: hand" onclick="javascript:HidePopup();"﹥ ﹤img alt="Hide Popup" src="App_Themes/Default/images/close_vista.gif" border="0" /﹥ ﹤/span﹥ ﹤/div﹥ ﹤div class="modalBody"﹥ You received ﹤strong﹥﹤span id="modalBody"﹥﹤/span﹥﹤/strong﹥ Email(s). ﹤/div﹥ ﹤/div﹥ ﹤/ProgressTemplate﹥ ﹤/asp:UpdateProgress﹥
這里的關閉X按鈕,調用javascript的腳本,等陣再說
然后當然要加scriptmanager控件了,如下
以下為引用的內容:
﹤asp:ScriptManager ID="ScriptManager1" runat="server"﹥ ﹤Services﹥ ﹤asp:ServiceReference Path="~/InboxService.asmx" /﹥ ﹤/Services﹥ ﹤/asp:ScriptManager﹥
這里調用了我們剛才寫的webservice
ASP.NET編程之實現彈窗報警提示:Script
以下為引用的內容:
﹤script type="text/javascript"﹥ var numberOfEmails_original= 0; var app = Sys.Application; app.add_init(applicationInitHandler); function applicationInitHandler(sender, args) { InboxService.GetLatestNumberOfEmails(OnCurrentNumberOfEmailsReady); }
首先,默認的當然是0封郵件了,有變量來存放當前郵件數量,之后是在ajax中的初始化事件中調用webserice的方法了,并且回調OnCurrentNumberOfEmailsReady方法,
以下為引用的內容:
function OnCurrentNumberOfEmailsReady(result, userContext, methodName) { numberOfEmails_original= result; // Start Checking StartChecking(); } OnCurrentNumberOfEmailsReady方法將WEBSERVICE調用的結果(當前狀態下有多少封信RESULT)返回給變量,然后調用sartchecking()方法 function StartChecking() { InboxService.GetLatestNumberOfEmails(OnLastestNumberOfEmailsReady); } startchecking方法,繼續回調OnLastestNumberOfEmailsReady方法 function OnLastestNumberOfEmailsReady(result, userContext, methodName) { var numberOfEmails_new= result; if (numberOfEmails_new ﹥ numberOfEmails_original) { ShowPopup(); $get("modalBody").innerHTML= numberOfEmails_new - numberOfEmails_original; // Update the count here numberOfEmails_original= numberOfEmails_new; } // Start checking again window.setTimeout(StartChecking, 10000); }
這個方法,用當前郵件數-原來郵件數,就得出新增了多少封郵件了,再將結果賦值給顯示區域的modalbody,并且記得把當前郵件數量的,變量更新哦(numberOfEmails_original= numberOfEmails_new;)
然后再用setimeout來設置每隔10000毫秒檢查一次了
以下為引用的內容:
function ShowPopup() { $get("UpdateProgress1").style.visibility= "visible"; $get("UpdateProgress1").style.display= "block"; } function HidePopup() { $get("UpdateProgress1").style.visibility= "hidden"; $get("UpdateProgress1").style.display= "none"; } ﹤/script﹥
ASP.NET編程之實現彈窗報警提示的相關信息就向你介紹到這里。
關于ASP.NET編程如何實現彈窗報警提示就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。