ASP.NET编程之实现弹窗报警提示浅析
创始人
2024-04-21 03:31:28
0

ASP.NET编程之实现弹窗报警提示的前言,在web应用中,比如OA中,经常要用到一些提示,比如EMAIL到达了,就做个象MSN那样的提示框,弹出给用户提示,然后再关闭。在asp.net 2.0的ajax中,这个现在不难做到了,刚好看到老外的一篇文章,讲解到,下面小结

比如有个数据库表,是存放EMAIL的,当数据库表中的EMAIL一有的时候,就提示用户,首先简单写一个WEBSERVICE如下

以下为引用的内容: 

  1. [ScriptService]  
  2. public class InboxService : System.Web.Services.WebService  
  3. {  
  4. [WebMethod]  
  5. public int GetLatestNumberOfEmails()  
  6. {  
  7. int numberOfEmails = 0;  
  8. using (SqlConnection conn = new SqlConnection(WebConfigurationManager.ConnectionStrings[0].ConnectionString))  
  9. {  
  10. using (SqlCommand cmd = new SqlCommand("GetLatestNumberOfEmails", conn))  
  11. {  
  12. cmd.CommandType = CommandType.StoredProcedure;  
  13. conn.Open();  
  14. numberOfEmails = (int)cmd.ExecuteScalar();  
  15. }  
  16. }  
  17. return numberOfEmails;  
  18. }  

这里要注意要在客户端通过AJAX调用WEBSERICE,要加上[ScriptService]

ASP.NET编程之实现弹窗报警提示在default.aspx中,首先加入一个updateprogress控件,如下

以下为引用的内容:

  1. ﹤asp:UpdateProgress DynamicLayout="False" ID="UpdateProgress1" runat="server"﹥  
  2. ﹤ProgressTemplate﹥  
  3. ﹤div id="modal" class="modal"﹥  
  4. ﹤div class="modalTop"﹥  
  5. ﹤div class="modalTitle"﹥My Inbox﹤/div﹥  
  6. ﹤span style="CURSOR: hand" onclick="javascript:HidePopup();"﹥  
  7. ﹤img alt="Hide Popup" src="App_Themes/Default/images/close_vista.gif" border="0" /﹥  
  8. ﹤/span﹥  
  9. ﹤/div﹥  
  10. ﹤div class="modalBody"﹥  
  11. You received ﹤strong﹥﹤span id="modalBody"﹥﹤/span﹥﹤/strong﹥  Email(s).  
  12. ﹤/div﹥  
  13. ﹤/div﹥  
  14. ﹤/ProgressTemplate﹥  
  15. ﹤/asp:UpdateProgress﹥ 

这里的关闭X按钮,调用javascript的脚本,等阵再说

然后当然要加scriptmanager控件了,如下

以下为引用的内容:

  1. ﹤asp:ScriptManager ID="ScriptManager1" runat="server"﹥  
  2. ﹤Services﹥  
  3. ﹤asp:ServiceReference Path="~/InboxService.asmx" /﹥  
  4. ﹤/Services﹥  
  5. ﹤/asp:ScriptManager﹥ 

这里调用了我们刚才写的webservice

ASP.NET编程之实现弹窗报警提示:Script

以下为引用的内容:

  1. ﹤script type="text/javascript"﹥  
  2. var numberOfEmails_original= 0;  
  3.  
  4. var app = Sys.Application;  
  5. app.add_init(applicationInitHandler);  
  6.  
  7. function applicationInitHandler(sender, args) {  
  8. InboxService.GetLatestNumberOfEmails(OnCurrentNumberOfEmailsReady);  
  9. }  

首先,默认的当然是0封邮件了,有变量来存放当前邮件数量,之后是在ajax中的初始化事件中调用webserice的方法了,并且回调OnCurrentNumberOfEmailsReady方法,

以下为引用的内容:

  1. function OnCurrentNumberOfEmailsReady(result, userContext, methodName) {  
  2. numberOfEmails_original= result;  
  3. // Start Checking  
  4. StartChecking();  
  5. }   
  6. OnCurrentNumberOfEmailsReady方法将WEBSERVICE调用的结果(当前状态下有多少封信RESULT)返回给变量,然后调用sartchecking()方法  
  7.  
  8. function StartChecking() {  
  9. InboxService.GetLatestNumberOfEmails(OnLastestNumberOfEmailsReady);  
  10. }  
  11.  
  12. startchecking方法,继续回调OnLastestNumberOfEmailsReady方法  
  13.  
  14. function OnLastestNumberOfEmailsReady(result, userContext, methodName) {  
  15. var numberOfEmails_new= result;  
  16. if (numberOfEmails_new ﹥ numberOfEmails_original) {  
  17. ShowPopup();  
  18. $get("modalBody").innerHTML= numberOfEmails_new - numberOfEmails_original;  
  19.  
  20. // Update the count here  
  21. numberOfEmails_original= numberOfEmails_new;  
  22. }  
  23. // Start checking again  
  24. window.setTimeout(StartChecking, 10000);  

这个方法,用当前邮件数-原来邮件数,就得出新增了多少封邮件了,再将结果赋值给显示区域的modalbody,并且记得把当前邮件数量的,变量更新哦(numberOfEmails_original= numberOfEmails_new;)

然后再用setimeout来设置每隔10000毫秒检查一次了

以下为引用的内容:

  1. function ShowPopup() {  
  2. $get("UpdateProgress1").style.visibility= "visible";  
  3. $get("UpdateProgress1").style.display= "block";  
  4. }  
  5. function HidePopup() {  
  6. $get("UpdateProgress1").style.visibility= "hidden";  
  7. $get("UpdateProgress1").style.display= "none";  
  8. }  
  9. ﹤/script﹥ 

ASP.NET编程之实现弹窗报警提示的相关信息就向你介绍到这里,希望对你有所帮助。

【编辑推荐】

  1. ASP.NET中JavaScript插入的方法浅析
  2. ASP.NET JavaScript和OLE DB设计网络日记浅析
  3. ASP.NET中Cookie删除的代码浅析
  4. ASP.NET编程嵌套If语句语法浅析
  5. ASP.NET编程中日期与时间的处理浅析

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...