如何更新网页的一个部分的内容?

gauss 2004-09-29 05:47:32
如何实现以下功能?给出思路即可。

网页有一个Text输入框,一个按钮。

点击按钮,当前页面不能刷新,就可以读取服务器数据库中的某些数据回来,并显示在Text输入框中。

说白了就是求CSDN左边的导航栏的部分更新实现的原理。
...全文
980 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
myfc 2004-09-29
  • 打赏
  • 举报
回复
我没有试过,但理论上可以,就是套一个Iframe,将表单提交到Iframe里面,由这个页进行刷新,然后再用javascript将值带回来,就实现此页不刷新而更新数据了,当然,这个Iframe页面可以设为宽高都是0,只是一个思路,没试过,有兴趣你可以试试
fason 2004-09-29
  • 打赏
  • 举报
回复
search "xmlhttp" in google
  • 打赏
  • 举报
回复
前些时间写了几篇关于XMLHTTP运用的实例.
(可以到http://dev.csdn.net/user/wanghr100看之前的几编关于XMLHTTP的介绍.)

近来看论坛上经常有人提问关于如何无刷新,自动更新数据.
传统上,我们浏览网页,如果加入最新的数据.只能是等我们重新向服务器端请求时才能显示出来.
但是,对于一些时效性很强的网站.传统的这种做法是不能满足的.

我们可以让程序自动刷新.定时向服务器请求数据.5秒取一次数据,10秒取一次数据.
利用XMLHTTP发出请求并取得数据.传到客户端,客户端重新组织并显示数据.

demo.htm 前台显示.

<script language="JavaScript">
function GetResult()
{
/*
*--------------- GetResult() -----------------
* GetResult()
* 功能:通过XMLHTTP发送请求,返回结果.
* 参数:str,字符串,发送条件.
* 实例:GetResult();
* author:wanghr100(灰豆宝宝.net)
* update:2004-5-27 19:02
*--------------- GetResult() -----------------
*/
var oBao = new ActiveXObject("Microsoft.XMLHTTP");
//特殊字符:+,%,&,=,?等的传输解决办法.字符串先用escape编码的.
//Update:2004-6-1 12:22
oBao.open("POST","Server.asp",false);
oBao.send();
//服务器端处理返回的是经过escape编码的字符串.
var strResult = unescape(oBao.responseText);
//将字符串分开.
var arrResult = strResult.split("###");
RemoveRow(); //删除以前的数据.
//将取得的字符串分开,并写入表格中.
for(var i=0;i<arrResult.length;i++)
{
arrTmp = arrResult[i].split("@@@");
num1 = arrTmp[0]; //字段num1的值
num2 = arrTmp[1]; //字段num2的值
row1 = tb.insertRow();
cell1 = row1.insertCell();
cell1.innerText = num1;
cell2 = row1.insertCell();
cell2.innerText = num2;
}
}

function RemoveRow()
{
//保留第一行表头,其余数据均删除.
var iRows = tb.rows.length;
for(var i=0;i<iRows-1;i++)
{
tb.deleteRow(1);
}
}

function MyShow()
{
//2秒自动刷新一次,2秒取得一次数据.
timer = window.setInterval("GetResult()",2000);
}
</script>

<body onload="MyShow()">
<p>
</p>
<table width="47%" height="23" border="0" cellpadding="1" cellspacing="0" id="tb">
<tr>
<td>num1</td>
<td>num2</td>
</tr>
</table>


Server.asp 后台读取数据

<% @Language="JavaScript" %>
<%
function OpenDB(sdbname)
{
/*
*--------------- OpenDB(sdbname) -----------------
* OpenDB(sdbname)
* 功能:打开数据库sdbname,返回conn对象.
* 参数:sdbname,字符串,数据库名称.
* 实例:var conn = OpenDB("database.mdb");
* author:wanghr100(灰豆宝宝.net)
* update:2004-5-12 8:18
*--------------- OpenDB(sdbname) -----------------
*/
var connstr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="+Server.MapPath(sdbname);
var conn = Server.CreateObject("ADODB.Connection");
conn.Open(connstr);
return conn;
}
var sResult = new Array();
var oConn = OpenDB("data.mdb");
//特殊字符:+,%,&,=,?等的传输解决办法.客户端字符是经过escape编码的
//所以服务器端先要经过unescape解码.
//Update:2004-6-1 12:22
var sql = "select num1,num2 from nums order by id";
var rs = oConn.Execute(sql);
while(!rs.EOF)
{
//一条记录用"###"隔开.每列数据用"@@@"隔开. 这是以只有两个列数据的情况.
sResult[sResult.length] = rs("num1").Value + "@@@" + rs("num2").Value
rs.MoveNext();
}
//escape解决了XMLHTTP。中文处理的问题.
Response.Write(escape(sResult.join("###")));
%>


数据库data.mdb
表 nums
id,自动编号
num1,文本
num2,文本

测试数据

id num1 num2
1 20.70 20.810
2 10.5 20.5
3 12.3 300
4 132 323
5 563 56
6 20 10


  • 打赏
  • 举报
回复
CSDN是读取左边的XML文件固定的
  • 打赏
  • 举报
回复
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0110)http://community.csdn.net/expert/deeptree/dtbar.asp?xmlsrc=/Expert/deeptree/Rooms/List.xml&csdnstyle=0&myie=ie -->
<HTML><HEAD><TITLE>Deeptree Controlbar</TITLE>
<SCRIPT language=javascript>

var strColumns_Current = "215,*";

function movenext()
{
top.deeptree.movenext();
}

function moveprevious()
{
top.deeptree.moveprevious();
}

function hidetoc()
{
strColumns_Current = top.mainframeset.cols

top.mainframeset.cols = "1,*";
top.contentbar.document.all("showtoc").style.display = "block";
}

function showtoc()
{
top.mainframeset.cols = strColumns_Current;
top.contentbar.document.all("showtoc").style.display = "none";
}

function synctoc()
{
top.location = top.location.pathname + "?url=" + top.content.location.pathname + top.content.location.search + top.content.location.hash;
}

function displaybutton()
{
document.all.showtoc.style.display = "block";
}

function mouseover(item)
{
switch (item)
{
case "moveprevious" :
window.status = "移动到菜单上一项 [SHIFT + TAB]";
document.all.imgMovePrevious.src = "Images/moveprevious2.gif";
break;

case "movenext" :
window.status = "移动到菜单下一项 [TAB]";
document.all.imgMoveNext.src = "Images/movenext2.gif";
break;

case "synctoc" :
window.status = "同步菜单中的当前页";
document.all.imgSyncToc.src = "Images/synctoc2.gif"
break;

case "hidetoc" :
window.status = "隐藏菜单";
document.all.imgHideToc.src = "Images/hidetoc2.gif"
break;
}

}

function mouseout(item)
{
switch (item)
{
case "moveprevious" :
window.status = "";
document.all.imgMovePrevious.src = "Images/moveprevious1.gif";
break;

case "movenext" :
window.status = "";
document.all.imgMoveNext.src = "Images/movenext1.gif";
break;

case "synctoc" :
window.status = "";
document.all.imgSyncToc.src = "Images/synctoc1.gif"
break;

case "hidetoc" :
window.status = "";
document.all.imgHideToc.src = "Images/hidetoc1.gif"
break;
}
}

function selectstart()
{
window.event.cancelBubble = true;
window.event.returnValue = false;
return false;
}

</SCRIPT>

<META content=noindex name=Robots>
<META http-equiv=Content-Type content=text/html;charset=gb2312>
<SCRIPT src="dtbar.files/get_css.js"></SCRIPT>

<META content="MSHTML 6.00.2900.2096" name=GENERATOR></HEAD>
<BODY class=color2 onselectstart=selectstart(); leftMargin=0 topMargin=0
marginwidth="0" marginheight="0">
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0>
<TBODY>
<TR>
<TD align=left>
<TABLE cellSpacing=0 cellPadding=0 border=0>
<TBODY>
<TR>
<TD width=4 height=20></TD>
<TD height=20><IMG id=imgMoveNext
onmouseover="mouseover('movenext');" title="移动到菜单下一项 [TAB]"
style="CURSOR: hand" onclick=movenext();
onmouseout="mouseout('movenext')" src="dtbar.files/movenext1.gif"
border=0></TD>
<TD width=2 height=20></TD>
<TD height=20><IMG id=imgMovePrevious
onmouseover="mouseover('moveprevious');"
title="移动到菜单上一项 [SHIFT + TAB]" style="CURSOR: hand"
onclick=moveprevious(); onmouseout="mouseout('moveprevious')"
src="dtbar.files/moveprevious1.gif" border=0></TD>
<TD width=8 height=20></TD></TR></TBODY></TABLE></TD>
<TD align=right>
<TABLE cellSpacing=0 cellPadding=0 border=0>
<TBODY>
<TR>
<TD height=20><IMG id=imgSyncToc onmouseover="mouseover('synctoc');"
title=同步菜单中的当前页 style="CURSOR: hand" onclick=synctoc();
onmouseout="mouseout('synctoc');" src="dtbar.files/synctoc1.gif"></TD>
<TD width=10 height=20><IMG height=20 src="dtbar.files/1pix.gif"
width=10></TD>
<TD height=20><IMG id=imgHideToc onmouseover="mouseover('hidetoc');"
title=隐藏菜单 style="CURSOR: hand" onclick=hidetoc();
onmouseout="mouseout('hidetoc');" src="dtbar.files/hidetoc1.gif"></TD>
<TD width=4 height=20><IMG height=20 src="dtbar.files/1pix.gif"
width=4></TD></TR></TBODY></TABLE></TD></TR></TBODY></TABLE></BODY></HTML>
gauss 2004-09-29
  • 打赏
  • 举报
回复
不用XMLHttp行不行?只用JavaScript。
gauss 2004-09-29
  • 打赏
  • 举报
回复
注意一定是要按下按钮之后才到服务器上取数据。
dream520 2004-09-29
  • 打赏
  • 举报
回复
VBscript+XMLhttp

28,391

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧