溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

ASP+AJAX+ACCESS數(shù)據(jù)庫怎么用

發(fā)布時間:2021-10-13 10:19:05 來源:億速云 閱讀:144 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)ASP+AJAX+ACCESS數(shù)據(jù)庫怎么用,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

AJAX+ASP基礎(chǔ)應(yīng)用,我們將分三步講解,如下。
1. 前臺AJAX代碼(javascript)的創(chuàng)建。
2. 后臺服務(wù)端ASP AJAX代碼的編寫。
3. ASP+AJAX+數(shù)據(jù)庫的實(shí)例演示及講解。

第一步:前臺AJAX代碼(javascript)的創(chuàng)建。
我們先創(chuàng)建一個index.html前臺文件,內(nèi)容代碼如下:

復(fù)制代碼 代碼如下:


<html>
<head>
<title>AJAX教程實(shí)例-AJAX教程實(shí)例-ASP+AJAX+ACCESS數(shù)據(jù)庫應(yīng)用-億速云原創(chuàng)ajax實(shí)例教程</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
</head>
<body>
<script> var xmlHttp

function showCustomer(str)
{
var url="getcustomer.asp?sid=" + Math.random() + "&q=" + str
xmlHttp=GetXmlHttpObject(stateChanged)
xmlHttp.open("GET", url , true)
xmlHttp.send(null)
}

function stateChanged()
{
if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
{
document.getElementById("txtHint").innerHTML=xmlHttp.responseText
}
}

function GetXmlHttpObject(handler)
{
var objXmlHttp=null

if (navigator.userAgent.indexOf("Opera")>=0)
{
alert("This example doesn't work in Opera")
return;
}
if (navigator.userAgent.indexOf("MSIE")>=0)
{
var strName="Msxml2.XMLHTTP"

if (navigator.appVersion.indexOf("MSIE 5.5")>=0)
{
strName="Microsoft.XMLHTTP"
}
try
{
objXmlHttp=new ActiveXObject(strName)
objXmlHttp.onreadystatechange=handler
return objXmlHttp
}
catch(e)
{
alert("Error. Scripting for ActiveX might be disabled")
return
}
}
if (navigator.userAgent.indexOf("Mozilla")>=0)
{
objXmlHttp=new XMLHttpRequest()
objXmlHttp.onload=handler
objXmlHttp.onerror=handler
return objXmlHttp
}
}
</script>
<form>請選擇用戶:
<select name="customers" onchange="showCustomer(this.value)">
<option value="1">億速云.by.alixixi.com</option>
<option value="2">哇塞網(wǎng)</option>
<option value="3">收音機(jī)</option>
</select>
</form><p>
<div id="txtHint"><b>網(wǎng)站信息...</b></div>
</p></body>
</html>


ajax代碼講解:
關(guān)鍵代碼為JS部分,其原理就是創(chuàng)建一個客戶的Microsoft.XMLHTTP對象,來完成前臺數(shù)據(jù)與服務(wù)端ASP的交互。
然后要注意的就是<select name="customers" onchange="showCustomer(this.value)">
這一行代碼,原理就是通過showCustomer(this.value)觸發(fā)AJAX的前臺腳本對象,將用戶在下拉列表選擇的結(jié)果數(shù)據(jù)通過Microsoft.XMLHTTP發(fā)送到服務(wù)端處理,再返回到前臺ID為txtHint的<div id="txtHint"><b>用戶信息...</b></div>層標(biāo)簽顯示出來。

第二步:后臺服務(wù)端ASP AJAX代碼的編寫。
創(chuàng)建完剛才的index.html,我們接著再創(chuàng)建一個getcustomer.asp文件,請確認(rèn)你的ASP環(huán)境一切OK:)
getcustomer.asp的代碼如下:

復(fù)制代碼 代碼如下:


<%
sql="SELECT * FROM CUSTOMERS WHERE CUSTOMERID="
sql=sql & request.querystring("q")
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open(Server.Mappath("ajaxjiaocheng.mdb"))
set rs = Server.CreateObject("ADODB.recordset")
rs.Open sql, conn
Response.CharSet = "GB2312"
if not rs.EOF then
response.write "<li>編號:"&rs(0)&"</li>"
response.write "<li>名稱:"&rs(1)&"</li>"
response.write "<li>點(diǎn)擊:"&rs(2)&"</li>"
response.write "<li>介紹:"&rs(3)&"</li>"
end if
rs.close
set rs = nothing
conn.close
set conn = nothing
%>


ajax代碼講解:
如果有asp基礎(chǔ)的朋友一看就能明白,連接數(shù)據(jù)庫代碼及跟據(jù)前臺發(fā)送過來的q參數(shù)查詢相應(yīng)的數(shù)據(jù)庫結(jié)果:

復(fù)制代碼 代碼如下:


sql="SELECT * FROM CUSTOMERS WHERE CUSTOMERID="
sql=sql & request.querystring("q")
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open(Server.Mappath("ajaxjiaocheng.mdb"))
set rs = Server.CreateObject("ADODB.recordset")
rs.Open sql, conn


接著要注意的就是這行代碼:
Response.CharSet = "GB2312" ‘這句很關(guān)鍵,解決ajax中文亂碼
很多人在使用AJAX過程中,經(jīng)常都會遇到ajax中文顯示變成亂碼的問題,其實(shí)在ASP+AJAX應(yīng)用中很容易解決這個問題,只需要在Response.Write語句輸出中文內(nèi)容前加入這行代碼,就可以輕松解決ajax中文亂碼問題。

繼續(xù)講解下段代碼,就是顯示相應(yīng)的數(shù)據(jù)庫查詢結(jié)果,關(guān)閉數(shù)據(jù)庫連接:

復(fù)制代碼 代碼如下:


if not rs.EOF then
response.write "<li>編號:"&rs(0)&"</li>"
response.write "<li>名稱:"&rs(1)&"</li>"
response.write "<li>點(diǎn)擊:"&rs(2)&"</li>"
response.write "<li>介紹:"&rs(3)&"</li>"
end if
rs.close
set rs = nothing
conn.close
set conn = nothing


第三步:ASP+AJAX+數(shù)據(jù)庫的實(shí)例演示及講解

一路下來,代碼非常精簡明了。下面我們再附上數(shù)據(jù)庫表的說明如下:

庫名:ajaxjiaocheng.mdb
表名: Customers

字段1:CustomerID 自動編號
字段2:Name 文本格式
字段3:NL 數(shù)字格式
字段4:Address 文本格式
看到這里,不知道你是否能理解AJAX的工作原理?建議你動手一步步跟著本教程編寫代碼并進(jìn)行測試。

本實(shí)例直觀的說可以這樣理解:
通過index.html頁面上的<select name="customers" onchange="showCustomer(this.value)"> 下拉列表選擇觸發(fā)JS代碼中的showCustomer(this.value)事件,將選中的option值<option value="1">億速云</option>
由以下的代碼傳遞給ASP文件:
var url="getcustomer.asp?sid=" + Math.random() + "&q=" + str
xmlHttp=GetXmlHttpObject(stateChanged)
xmlHttp.open("GET", url , true)
xmlHttp.send(null)

ASP文件接收到q參數(shù)后,輸出數(shù)據(jù)庫相應(yīng)的查詢結(jié)果,然后js會檢查asp的輸出狀態(tài),如果輸出完成后會把結(jié)果返回到index.html文件ID為txtHint的標(biāo)簽上。

關(guān)于“ASP+AJAX+ACCESS數(shù)據(jù)庫怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI