ASP中不刷新页面,动态读取数据库

原创 2004年06月23日 15:10:00

1.效果图:

效果图

2.源程序

1.jsCallASP.asp

<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>不刷新页面,动态读取数据库</title>
<script language="javascript" src="function.js"></script>
<script language="javascript">
 function getTables(obj){
  var server=txtServer.value;
  var database=txtDatabase.value;
  var jsSrc="getTables.asp?obj=selTable&server=" + server + "&database=" + database + "&rnd=" + Math.random();
  if(server==""||database=="") {alert('请填写完整!');return;}
  obj.value='读取中...';
  obj.disabled=true;
  reloadJs(js,jsSrc);
 }

 function getRecords(obj){
  var server=txtServer.value;
  var database=txtDatabase.value;
  var table=selTable.value;
  var jsSrc="getRecords.asp?obj=DisData&server=" + server + "&database=" + database + "&table=" + table + "&rnd=" + Math.random();
  if(server==""||database==""||table=="") {alert('请填写完整!');return;}
  obj.value='读取中...';
  obj.disabled=true;
  reloadJs(js,jsSrc);
 } 
</script>
</head>

<body>
<p>不刷新页面,动态读取数据库</p>
<script language="javascript" id="js" src=""></script>
<table width="421" border="0">
  <tr>
    <td width="146">Sql Server服务器: </td>
    <td width="265"><input name="txtServer" type="text" id="txtServer" value="localhost" readonly></td>
  </tr>
  <tr>
    <td>数据库:</td>
    <td><input name="txtDatabase" type="text" id="txtDatabase" value="Northwind" readonly>    </td>
  </tr>
  <tr>
    <td>表:</td>
    <td><select name="selTable" id="selTable">
        </select>
    <input name="cmdRefresh" type="button" id="cmdRefresh" value="刷 新" onClick="JavaScript:getTables(this)"> </td>
  </tr>
  <tr>
    <td>前100条数据:</td>
    <td><input name="cmdRead" type="button" id="cmdRead" value="读 取" onClick="JavaScript:getRecords(this)"></td>
  </tr>
  <tr>
    <td colspan="2">
 <div id="DisData"></div>
 </td>
  </tr>
</table>
</body>
</html>

2.getTables.asp

<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
<%
Dim CnStr,SQL,Rs,ServerName,DatabaseName,Obj
ServerName=Request.QueryString("server")
DatabaseName=Request.QueryString("database")
Obj=Request.QueryString("obj")
Set Rs=Server.CreateObject("ADODB.Recordset")
CnStr="Driver={SQL Server};Server=" & ServerName & ";Database=" & DatabaseName & ";uid=sa;pwd=sa"
SQL="select name from sysobjects where type='u' and status>0"
Rs.Open SQL,CnStr,1,1
If Not Rs.Eof then
 Response.Write("ClearSelect(" & Obj & ");" & vbcrlf)
 While not Rs.eof
  text=Rs("name")
  value=Rs("name")
  Response.Write("FillSelect(" & Obj & ",'" & text & "','" & value & "');" & vbcrlf)
  Rs.MoveNext
 Wend
End If
Rs.Close
Set Rs=Nothing
%>
cmdRefresh.value="刷 新";
cmdRefresh.disabled=false;

3.getRecords.asp

<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
<%
On Error Resume Next
Dim CnStr,SQL,Rs,ServerName,DatabaseName,Obj
ServerName=Request.QueryString("server")
DatabaseName=Request.QueryString("database")
Table=Request.QueryString("Table")
Obj=Request.QueryString("obj")
Set Rs=Server.CreateObject("ADODB.Recordset")
CnStr="Driver={SQL Server};Server=" & ServerName & ";Database=" & DatabaseName & ";uid=sa;pwd=sa"
SQL="select top 100 * from [" & table & "]"
Rs.Open SQL,CnStr,1,1

If Not Rs.Eof then
 Response.Write("SetHTML(" & Obj & ",'');" & vbcrlf)
 outHTML="<table border=1><tr>"
 for i=0 to Rs.Fields.count-1
  outHTML=outHTML & "<th>" & Rs.Fields(i).Name & "</th>"
 next
 outHTML=outHTML & "</tr>"
 While not Rs.eof
  outHTML=outHTML & "<tr>"
  For i=0 to Rs.Fields.count-1
   FieldType=Rs.Fields(i).Type
   FieldValue=Rs.Fields(i).Value
   Select Case FieldType
    Case 128
     outHTML=outHTML & "<td>[Binary]</td>"
    Case 205
     outHTML=outHTML & "<td>[LongVarBinary]</td>"
    Case Else
     outHTML=outHTML & "<td>" & FieldValue & "</td>"
   End Select
  Next
  outHTML=outHTML & "</tr>"
  Rs.MoveNext
 Wend
 outHTML=outHTML & "</table>"
 outHTML=Replace(outHTML,vbcrlf,"<br>")
 outHTML=Replace(outHTML,"""","/""")
 Response.Write("var HTML=""" & outHTML & """;" & vbcrlf)
 Response.Write("SetHTML(" & Obj & ",HTML);" & vbcrlf)
Else
 Response.Write("SetHTML(" & Obj & ",'没有记录!');" & vbcrlf)
End If
Rs.Close
Set Rs=Nothing
%>
cmdRead.value="读 取";
cmdRead.disabled=false;

4.Function.js

var _onjsload=null;
function reloadJs(obj,jsfile)
{
    _onjsload= function(){window.status=jsfile + " is loaded.";}
    obj.src=jsfile;
}

function jsLoadReady()
{
    if(_onjsload!=null)
    {
        _onjsload();
        _onjsload=null;
    }
}

function FillSelect(obj,text,value){
 
 var oOption = document.createElement("OPTION");
 oOption.text=text;
 oOption.value=value;
 obj.add(oOption);
}

function ClearSelect(obj){
 for(var i=obj.length;i>=0;i--){
  obj.remove(i);
 }
}

function SetHTML(obj,value)
{
 obj.innerHTML=value;
}

3.参与资料
Web编程中的脚本替换技术
http://www.blueidea.com/bbs/newsdetail.asp?id=1266892&posts=current

ASP环境下实现无刷新查询程序

  • 2009年12月01日 17:36
  • 19KB
  • 下载

jQuery+ASP动态实时刷新数据库数值,在线人数

  • 2015年08月18日 07:57
  • 33KB
  • 下载

使用AJAX实时显示数据

 使用AJAX实时显示数据Display data updates in real-time with AJAXhttp://encosia.com/2007/07/25/display-data-u...
  • dreamliner
  • dreamliner
  • 2008年03月11日 20:26
  • 2851

实现无刷新加载数据(asp+ajax)

数据载入中…… function getXML(URL){          if (window.XMLHttpRequest)         {             var xmlh...
  • shunzi110
  • shunzi110
  • 2007年03月21日 16:55
  • 2419

ASP.NET Dynamic Data (动态数据)

ASP.NET Dynamic Data ASP.NET动态数据--无代码建站技术
  • eryongyan
  • eryongyan
  • 2013年12月18日 17:20
  • 1867

无刷新显示即时更新数据两例

无刷新显示即时更新数据两例     因最近做网站需要用到无刷新数据,所以在网上查了一些资料,无刷新数据的实现无外乎用javascript或xmlhttp或iframe来实现。在网上找到一代码不是不能用...
  • cui55
  • cui55
  • 2006年07月06日 12:16
  • 806

asp.net 检测页面是否刷新

public partial class TestRefresh : ProAspNet20.CS.Components.Page { protected void AddContactButto...
  • u012576247
  • u012576247
  • 2014年09月04日 14:25
  • 1084

p.net 子页面刷新父页面,页面自动刷新方法汇总

1) 10表示间隔10秒刷新一次 2) window.location.reload(true); 如果是你要刷新某一个iframe就把window给换成frame的名字或ID号 3) win...
  • q46mu28wem
  • q46mu28wem
  • 2017年05月22日 19:55
  • 257

asp:Button 点击自动刷新问题的解决方案

问题描述: asp.net网页中使用asp:Button,属性action连接后台的C#函数,在javascript中设置点击Button,开始直接用的时候,后台能接到数据,但页面会刷新,这不是我想...
  • lyxin10277
  • lyxin10277
  • 2014年03月27日 10:35
  • 1562

ASP批量按行读取记事本txt文字添加到SQL数据库_逐行读取文本txt到数据库

 
  • engling
  • engling
  • 2010年06月23日 11:02
  • 1216
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP中不刷新页面,动态读取数据库
举报原因:
原因补充:

(最多只允许输入30个字)