欢迎您访问我爱IT技术网,今天小编为你分享的编程技术是:【一个无刷新效果定时自动更新页面的例子】,下面是详细的分享!
一个无刷新效果定时自动更新页面的例子
首先在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();
}
}
}
以上所分享的是关于一个无刷新效果定时自动更新页面的例子,下面是编辑为你推荐的有价值的用户互动:
相关问题:在html中有没有只定时刷新一个页面中的部分页面的功能
答:setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数。 setInterval(function(){}, 500); 毫秒计数 >>详细
相关问题:网页中实现当数据库一有新的消息时,网页页面无刷...
答:可以直接用Timer控件。 前台: 后台: protected void Timer1_Tick(object sender, EventArgs e) { //读取数据库,判断是否有数据更新,有则弹出消息提示 } >>详细
相关问题:用AJAX做一个定时刷新的效果
答:HTML JS $(document).ready(function(){ refreshForm(); }); function refreshForm(){ $("input").each(function(){ var number = parseInt($(this).val()) + 1; $(this).val(number); }); setTimeout(refreshForm, 5000); } >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
