一個(gè)無(wú)刷新效果定時(shí)自動(dòng)更新頁(yè)面的例子_.Net教程
推薦:看看一個(gè).net版對(duì)話框控件一直不太喜歡默認(rèn)的對(duì)話框樣式,網(wǎng)上看到個(gè)比較好看的對(duì)話框,自己修改了下做成了.net版,只在IE下測(cè)試過(guò),其他的還沒(méi)有來(lái)得及測(cè)試,具體還三個(gè)問(wèn)題沒(méi)有解決: 1、我沒(méi)辦法像微軟ajax-script
首先在ASP.Net創(chuàng)建兩個(gè)WebForm頁(yè),分別命名為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>無(wú)標(biāo)題頁(yè)</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 2.0,無(wú)刷新頁(yè)面新境界“無(wú)刷新頁(yè)面”,只是一種不確切的效果描述(其實(shí)還有其他各種方法來(lái)實(shí)現(xiàn)這個(gè)效果),更確切的說(shuō)法是:在頁(yè)面上用JavaScript調(diào)用服務(wù)器端的一個(gè)方法,然后處理返回的數(shù)據(jù)。實(shí)現(xiàn)它最標(biāo)
- asp.net如何得到GRIDVIEW中某行某列值的方法
- .net SMTP發(fā)送Email實(shí)例(可帶附件)
- js實(shí)現(xiàn)廣告漂浮效果的小例子
- asp.net Repeater 數(shù)據(jù)綁定的具體實(shí)現(xiàn)
- Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
- Asp.net獲取客戶(hù)端IP常見(jiàn)代碼存在的偽造IP問(wèn)題探討
- VS2010 水晶報(bào)表的使用方法
- ASP.NET中操作SQL數(shù)據(jù)庫(kù)(連接字符串的配置及獲取)
- asp.net頁(yè)面?zhèn)髦禍y(cè)試實(shí)例代碼
- DataGridView - DataGridViewCheckBoxCell的使用介紹
- asp.net中javascript的引用(直接引入和間接引入)
- 三層+存儲(chǔ)過(guò)程實(shí)現(xiàn)分頁(yè)示例代碼
.Net教程Rss訂閱編程教程搜索
.Net教程推薦
- 點(diǎn)擊按鈕提交后如何使按鈕變灰不可用
- .NET中應(yīng)用程序內(nèi)共享UdpClient聯(lián)機(jī)的實(shí)現(xiàn)方法
- ASP.NET對(duì)IIS中的虛擬目錄進(jìn)行操作
- C#刪除多重文件夾
- 關(guān)于C#靜態(tài)構(gòu)造函數(shù)的幾點(diǎn)說(shuō)明
- 從文本文件讀取行信息
- 揭秘設(shè)計(jì)ASP.NET應(yīng)用程序的七大妙招
- 使用ASP.NET內(nèi)置類(lèi)生成圖片縮略圖及水印
- 解析ASP.NET 2.0創(chuàng)建母版頁(yè)引來(lái)的麻煩
- 對(duì)比JAVA和.NET兩個(gè)平臺(tái)的安全功能
- 相關(guān)鏈接:
- 教程說(shuō)明:
.Net教程-一個(gè)無(wú)刷新效果定時(shí)自動(dòng)更新頁(yè)面的例子
。