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

类别:Asp 点击:0 评论:0 推荐:

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

本文地址:http://com.8s8s.com/it/it8939.htm