关于我们 广告服务 社区论坛
设为首页 加入收藏

行业新闻
服 务 器
模版下载
建站指南
冲浪宝典
办公软件
网站运营
操作系统
QQ 专题
网页制作
安全防御
视频教程
网络编程
SEO专区
软件下载
图像设计
Cisco
网页特效
Wap 技术
联盟赚钱
网页素材
 首页 | 企业建站 | 网页制作 | 网站运营 | 网络编程 | 图像设计 | 冲浪宝典 | 操作系统 | SEO专区 | 联盟赚钱 | Cisco

欢迎来到e天下网络首页>>网络编程>>ASPNET>>正文|一个无刷新效果定时自动更新页面的例子

一个无刷新效果定时自动更新页面的例子

[ 来路:21kn.com    时间:2007-7-8 17:53:26    点击: ]

 

  一个无刷新效果定时自动更新页面的例子(ASP.NET2.0-应用xmlhttp)

  首先在ASP.Net创建两个WebForm页,分别命名为Default1,Default2。下面给出代码清单:

//Default1.aspx

<%@ Page Language="C#" Debug="true" AutoEventWireup="true" CodeFile="Default1.aspx.cs" Inherits="Default1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html Xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
  <title>无标题页</title> 
  <script type="text/javascript">
    var XmlHttp;
    function createXmlHttpRequest()
    {
      if (window.XmlHttpRequest)
      {
        XmlHttp = new XmlHttpRequest();
      }
      else if (window.ActiveXObject)
      {
        try
        {
        XmlHttp = new ActiveXObject("MsXml2.XmlHTTP");
        }
        catch (e1)
        {
        try
        {
          XmlHttp = new ActiveXObject("Microsoft.XmlHTTP");
        }
        catch (e2)
        {}
        }
      }
      return XmlHttp;    
    }
    function doStart() {
        createXmlHttpRequest();
        var url = "Default2.aspx?task=reset";
        XmlHttp.open("POST", url, true);
        XmlHttp.onreadystatechange = startCallback;
        XmlHttp.send(null);
    }
    function startCallback() {
        if (XmlHttp.readyState == 4) {
          if (XmlHttp.status == 200) {
            setTimeout("pollServer()", 1000);
            refreshTime();
          }
          else {
            alert("HTTP error: "+XmlHttp.status);
          }
        }
    }
    function pollServer() {
        createXmlHttpRequest();
        var url = "Default2.aspx?task=foo";
        XmlHttp.open("POST", url, true);
        XmlHttp.onreadystatechange = pollCallback;
        XmlHttp.send(null);
    }
  function refreshTime(){
    var time_span = document.getElementById("time");
    var time_val = time_span.innerHTML;
    var int_val = parseInt(time_val);
    var new_int_val = int_val - 1;
    if (new_int_val > -1) {
        setTimeout("refreshTime()", 1000);
        time_span.innerHTML = new_int_val;
    } else {
        time_span.innerHTML = 1;
    }
  }
  function pollCallback() {
    if (XmlHttp.readyState == 4) {
        if (XmlHttp.status == 200) {
          var message = XmlHttp.responseXml.getElementsByTagName("message")[0].firstChild.data;
          if (message != "done") {
            var new_row = createRow(message);
            var table = document.getElementById("dynamicUpdateArea");
            var table_body = table.getElementsByTagName("tbody").item(0);
            var first_row = table_body.getElementsByTagName("tr").item(1);
            table_body.insertBefore(new_row, first_row);
            setTimeout("pollServer()", 1000);
            refreshTime();
          }
        }
        else {
          alert("HTTP error: "+XmlHttp.status);
       }
    }
  }
  function createRow(message) {
    var row = document.createElement("tr");
    var cell = document.createElement("td");
    var cell_data = document.createTextNode(message);
    cell.appendChild(cell_data);
    row.appendChild(cell);
    return row;
  }
</script>
</head>
<body>
  <form id="form1" runat="server" >
    <h1>Ajax Dynamic Update Example</h1>
    This page will automatically update itself:
      <input type="button" value="Launch" id="go" onclick="doStart();"/>
    <p/>
    Page will refresh in <span id="time">1</span> seconds.
    <p/>
    <table id="dynamicUpdateArea" align="left">
    <tbody>
      <tr id="row0"><td></td></tr>
    </tbody>
  </table>
  </form>
</body>
</html>

//Default2.cs

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class Default2: System.Web.UI.Page
{
  private static int counter = 1;
  protected void Page_Load(object sender, EventArgs e)
  {
    String res = "";
    String task = this.Request.Params["task"];
    String message = "";
    if (!string.IsNullOrEmpty(task))
    {
        if (task.Equals("reset"))
        {
          counter = 1;
        }
        else
        {
          switch (counter)
          {
            case 1: message = "Steve walks on stage"; break;
            case 2: message = "iPods rock"; break;
            case 3: message = "Steve says Macs rule"; break;
            case 4: message = "Change is coming"; break;
            case 5: message = "Yes, OS X runs on Intel - has for years"; break;
            case 6: message = "Macs will soon have Intel chips"; break;
            case 7: message = "done"; break;
          }
          counter++;
        }
        res = "<message>" + message + "</message>";
        Response.ContentType = "text/Xml";
        Response.AppendHeader("Cache-Control", "no-cache");
        Response.Write("<response>");
        Response.Write(res);
        Response.Write("</response>");
        Response.End();
   }
  }
}

::::站长友情提示:多花一分钟学点什么都好::::

 

上一篇:ASP.NET移动开发之讲解SelectionList控件  下一篇:ASP.NET 2.0中使用样式、主题和皮肤

 ::热点信息::

 

= = 免责声明 = =

① 欢迎转载我网所刊信息,请注明“来源:E天下网络”。
② 凡本网注明“来源:XXX(非E天下网络)”的作品,均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如因作品内容、版权和其它问题需要同本网联系的,请在30日内进行。
※联系方式:Airtofly@163.com

::推荐文章::

 

ASP教程:详细学习ASP的内置对象

::图像设计::

 

动态图片搜索家——GIF RUNN
软件搜索利器——FileFerret
实例说明构图要讲规律
Character Builder让你尽展靓
全景图速成者Cool360
三维模型速成工具——Canoma
剪贴专家SmartBoard 32
新世纪的图像处理利器——Ph
更多内容..

 

 

关于我们 广告服务 友情链接 合作伙伴 社区论坛 免责声明

Copyright © 2007   21kn.com Inc. All rights reserved.e天下网络工作室

网站白天客服QQ:26875416 (非24小时)  合作QQ:597004688    粤ICP备06026423号