使用Ajax动态的显示时间

         在最初学习Ajax的时候视频中有一个例子是动态的加载服务器端的时间显示在前台页面,当时不懂原理,看着视频敲了一样的代码,就是运行不出结果,现在在项目中遇到了客户的需求就是需要在前台页面动态的显示时间,刚开始被分配到这个任务的时候有点不知道从哪里下手,心里就感觉自己不会上网查资料做出来发现So Easy!而且还不是一种方法。下面来看以下的两种方法。

第一种:中规中矩的原始Ajax方法。

         首先在要显示时间的地方使用任何可以显示文本的标签,本例中使用label

                 

         <label id=lbl></label>

         然后开始使用我们在学习Ajax时非常熟悉的XMLHttpRequest对象开始实现。              

        <script>
            function GetXmlHttp()   //判断是否已经存在了XMLHttpRequest对象
            {
               return window.XMLHttpRequest ? newXMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
            }
    
            function GetRequest()
            {
               var url ="FHome/GetTime";//URL格式:Controller/方法
               xmlHttp = GetXmlHttp();          //调用GetXMLHTTP方法,以获得XMLHttpRequest对象
               xmlHttp.onreadystatechange =OnReadyStateChange;//调用回调方法
               xmlHttp.open("GET",url, true);
               xmlHttp.send("");
            }
    
            function OnReadyStateChange()
            {
               if(xmlHttp.readyState == 4)
               {
                  document.getElementById("lbl").innerHTML =xmlHttp.responseText + "<br />更新间隔: " +interval + "ms";
               }
            }
    
           var xmlHttp;
           varinterval = 1000; //重要的需要设计一个时间间隔
           vartimer = window.setInterval(GetRequest, interval);//每1000ms调用一次显示时间的方法
       </script>

         最后看一下Controller中的方法     

      public ActionResult  GetTime()
      {         
         Response.Write(DateTime.Now); //获取现在的时间
         Response.End();
         return null;
      }

第二种:使用JQuery封装好的Ajax

         首先前台的要求不变,相应的位置上,任何可以显示文本的标签,这里使用span                  

       <spanid=time></span>

         然后在页面中引入JQuery,版本不限,只有封装了ajax,本例中的版本为1.8.0的              

       <scriptsrc="../../Content/JqueryEasyUI/jquery-1.8.0.min.js"></script>

         开始调用

                   

       <scripttype="text/javascript">
             setInterval(GetTime, 1000); //每一秒钟调用一次
             function GetTime() {
                $.ajax({
                     type:"post",
                     contentType:"application/json",  //接收到的数据要求格式
                     url:"FHome/GetTime1",        //调用Controller中的方法返回时间
                     success:function (result) {      //如果成功就显示时间       
                         $('#time').text(result);
                      },
                      error: function() {
                         alert(“时间加载失败”);           //失败给出提示
                       }
                       })
                }
         </script>

         Controller中的方法如下                 

       publicstring GetTime1()
       {
           return DateTime.Now.ToString();
       }

小结

         两种方法一个是原生态的,一个是JQuery-Ajax,相比后者的使用更加的简单,这也是JQuery作用的体现吧,但是本质上是没有区别的,重点都是要设置每1秒调用一次显示时间的方法。两种方法根据自己的实际情况进行选择。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 28
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值