主頁(yè) > 知識(shí)庫(kù) > AJAX和JSP混合使用方法實(shí)例

AJAX和JSP混合使用方法實(shí)例

熱門標(biāo)簽:ai機(jī)器人電銷資源 個(gè)人怎樣在百度地圖標(biāo)注地名 超級(jí)大富翁地圖標(biāo)注 騰訊地圖標(biāo)注位置能用多久 云呼外撥網(wǎng)絡(luò)電話系統(tǒng) 機(jī)器人電銷騙局揭秘 越南河內(nèi)地圖標(biāo)注 硅語(yǔ)電話機(jī)器人公司 地圖標(biāo)注項(xiàng)目怎么樣

首先要知道AJAX 是一種在無(wú)需重新加載整個(gè)網(wǎng)頁(yè)的情況下,能夠更新部分網(wǎng)頁(yè)的技術(shù)。

什么是 AJAX ?

AJAX = 異步 JavaScript 和 XML。

AJAX即“Asynchronous Javascript And XML”(異步JavaScript和XML),是指一種創(chuàng)建交互式網(wǎng)頁(yè)應(yīng)用的網(wǎng)頁(yè)開發(fā)技術(shù)。AJAX 是一種用于創(chuàng)建快速動(dòng)態(tài)網(wǎng)頁(yè)的技術(shù)。

通過在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁(yè)實(shí)現(xiàn)異步更新。這意味著可以在不重新加載整個(gè)網(wǎng)頁(yè)的情況下,對(duì)網(wǎng)頁(yè)的某部分進(jìn)行更新。

傳統(tǒng)的網(wǎng)頁(yè)(不使用 AJAX)如果需要更新內(nèi)容,必需重載整個(gè)網(wǎng)頁(yè)面。

AJAX工作原理


AJAX請(qǐng)求

ajax請(qǐng)求是依靠XMLHttpRequest對(duì)象,因此在請(qǐng)求前先要?jiǎng)?chuàng)建其對(duì)象

var xmlhttp;
//兼容性寫法創(chuàng)建請(qǐng)求實(shí)例,IE5 6支持else里面的方法
if (window.XMLHttpRequest){
xmlhttp = new XMLHttpRequest();
}else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}

接著向服務(wù)器發(fā)送請(qǐng)求

open函數(shù)有三個(gè)參數(shù),請(qǐng)求方式,請(qǐng)求地址,請(qǐng)求是異步還是同步
send(String)函數(shù)有一個(gè)參數(shù),只有當(dāng)請(qǐng)求方式為post的時(shí)候,String參數(shù)才需要帶上

那么GET和POST的區(qū)別呢?

與 POST 相比,GET 更簡(jiǎn)單也更快,并且在大部分情況下都能用。

然而,在以下情況中,請(qǐng)使用 POST 請(qǐng)求:

無(wú)法使用緩存文件(更新服務(wù)器上的文件或數(shù)據(jù)庫(kù))
向服務(wù)器發(fā)送大量數(shù)據(jù)(POST 沒有數(shù)據(jù)量限制)
發(fā)送包含未知字符的用戶輸入時(shí),POST 比 GET 更穩(wěn)定也更可靠

//設(shè)置傳送方式,地址,以及同步還是異步
xmlhttp.open("GET","Test.jsp?value="+escape(value),true);
xmlhttp.onreadystatechange = callback;//狀態(tài)改變的時(shí)候執(zhí)行這個(gè)函數(shù),用來(lái)判斷是否請(qǐng)求完畢
xmlhttp.send();//請(qǐng)求服務(wù)器,如果使用post方式,則send里面要帶上傳遞的參數(shù)
//post方式
/**
xmlhttp.open("POST","Test.jsp",true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlhttp.send("value="+value);
*/

然后服務(wù)器端處理并返回,這個(gè)放在實(shí)例里面有具體代碼

在回調(diào)函數(shù)callback中設(shè)置對(duì)返回響應(yīng)

onreadystatechange 存儲(chǔ)函數(shù)(或函數(shù)名),每當(dāng) readyState 屬性改變時(shí),就會(huì)調(diào)用該函數(shù)。
readyState 存有 XMLHttpRequest 的狀態(tài)。從 0 到 4 發(fā)生變化。

0: 請(qǐng)求未初始化
1: 服務(wù)器連接已建立
2: 請(qǐng)求已接收
3: 請(qǐng)求處理中
4: 請(qǐng)求已完成,且響應(yīng)已就緒

status 200: “OK”

404: 未找到頁(yè)面

相應(yīng)服務(wù)器的類型

responseText 獲得字符串形式的響應(yīng)數(shù)據(jù)。

responseXML 獲得 XML 形式的響應(yīng)數(shù)據(jù)。 這個(gè)一般當(dāng)open里面的url為xml文件的時(shí)候用

function callback(){
//請(qǐng)求完成表示
if(xmlhttp.readyState ==4  xmlhttp.status==200){
//設(shè)置相應(yīng)操作
}
}
}

總體來(lái)說就這幾個(gè)步驟,下面是詳細(xì)代碼

實(shí)例

首先創(chuàng)建一個(gè)文本框,用于測(cè)試用戶名,并且添加監(jiān)聽事件onblur,意思是當(dāng)失去焦點(diǎn)則執(zhí)行,并在其后面創(chuàng)建個(gè)span空標(biāo)簽,用來(lái)動(dòng)態(tài)顯示信息,表示名稱是否被占用

form method="post" action="AJAX.jsp">
table>
tr>
td>input type="text" id="userid" onblur="checkuser()" >span style="color: red" id="spanid">/span>/td>
/tr>
/table>
/form>

接下來(lái)是JS代碼,使用AJAX把輸入的內(nèi)容發(fā)送到服務(wù)器,服務(wù)器來(lái)檢驗(yàn)

var xmlhttp;
function checkuser(){
var value = document.getElementById("userid").value;
//兼容性寫法創(chuàng)建請(qǐng)求實(shí)例,IE5 6支持else里面的方法
if (window.XMLHttpRequest){
xmlhttp = new XMLHttpRequest();
}else {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
//設(shè)置傳送方式,地址,以及同步還是異步
xmlhttp.open("GET","Test.jsp?value="+escape(value),true);
xmlhttp.onreadystatechange = callback;//狀態(tài)改變的時(shí)候執(zhí)行這個(gè)函數(shù),用來(lái)判斷是否請(qǐng)求完畢
xmlhttp.send();//請(qǐng)求服務(wù)器
}

然后服務(wù)器端獲得數(shù)據(jù)后寫回

%
response.setHeader("Cache-Control","no-store");//HTTP1.1
response.setHeader("Pragma","no-cache");//HTTP1.0
response.setDateHeader("Expires",0);//禁止在服務(wù)器中緩存
String value = request.getParameter("value");//獲取傳送過來(lái)的參數(shù)
response.getWriter().write(value);//模擬數(shù)據(jù)寫回
%>

客戶端再回調(diào)函數(shù)中處理服務(wù)器寫回的數(shù)據(jù)

/**
* 回調(diào)函數(shù)
*/
function callback(){
//請(qǐng)求完成表示
if(xmlhttp.readyState ==4  xmlhttp.status==200){
alert(xmlhttp.responseText);//相應(yīng)返回的text
// alert(xmlhttp.responseXML);//相應(yīng)返回的xml
if (xmlhttp.responseText){//這里直接判斷不為空,應(yīng)該根據(jù)數(shù)據(jù)庫(kù)返回值來(lái)進(jìn)行不同的顯示
var spanid = document.getElementById("spanid");
spanid.innerHTML = "注冊(cè)成功";
}
}
}

效果就是當(dāng)輸入框失去焦點(diǎn)就立即判斷,當(dāng)然實(shí)際判斷是要連接數(shù)據(jù)庫(kù)的,為了簡(jiǎn)單就直接打印出來(lái)了

以上內(nèi)容是針對(duì)AJAX和JSP混合使用方法實(shí)例,希望對(duì)大家有所幫助!

您可能感興趣的文章:
  • 使用Ajax生成的Excel文件并下載的實(shí)例
  • jQuery ajax中使用confirm,確認(rèn)是否刪除的簡(jiǎn)單實(shí)例
  • 實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法
  • jQuery使用$.ajax提交表單完整實(shí)例
  • 實(shí)例詳解angularjs和ajax的結(jié)合使用
  • jQuery Ajax使用實(shí)例
  • ThinkPHP中ajax使用實(shí)例教程
  • Ajax和$.ajax使用實(shí)例詳解(推薦)

標(biāo)簽:內(nèi)蒙古 林芝 鄭州 海南 邢臺(tái) 遼源 舟山 洛陽(yáng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《AJAX和JSP混合使用方法實(shí)例》,本文關(guān)鍵詞  AJAX,和,JSP,混合,使用方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《AJAX和JSP混合使用方法實(shí)例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于AJAX和JSP混合使用方法實(shí)例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章