Ajax核心XMLHttpRequest總結(jié)
Ajax:即"Asynchronous JavaScript and XML"(異步JavaScript和XML),一門(mén)綜合性的技術(shù):運(yùn)用JavaScript對(duì)象XMLHttpRequest進(jìn)行異步數(shù)據(jù)交換;JavaScript操作DOM實(shí)現(xiàn)動(dòng)態(tài)效果;運(yùn)用XHTML+CSS表達(dá)信息;XML和XSLT操作數(shù)據(jù)。此篇文章重點(diǎn)介紹使用XMLHttpRequest對(duì)象與服務(wù)器端進(jìn)行異步數(shù)據(jù)交換。
使用方法
XMLHttpRequest五步使用法:
1.創(chuàng)建對(duì)象;
2.注冊(cè)回調(diào)函數(shù);
3.使用open方法設(shè)置和服務(wù)器交互的基本信息;
4.設(shè)置發(fā)送的數(shù)據(jù),開(kāi)始和服務(wù)器端交互;
5.實(shí)現(xiàn)回調(diào)函數(shù)。
由于每次應(yīng)用XMLHttpRequest對(duì)象時(shí),都要進(jìn)行五步操作,因此,可將該對(duì)象的使用封裝為js文件中,傳遞部分參數(shù)使用其方法就可以完成相應(yīng)功能,實(shí)現(xiàn)如下:
//使用封裝方法人員只提供http的請(qǐng)求,url地址,數(shù)據(jù),成功和失敗的回調(diào)的方法
//1.定義XMLHttpRequest對(duì)象的構(gòu)造方法
var MyXMLHttpRequest =function(){
var xmlhttprequest;
if(window.XMLHttpRequest){
//IE7,IE8,FireFox,Mozillar,Safari,Opera
//alert("IE7,IE8,FireFox,Mozillar,Safari,Opera");
xmlhttprequest = new XMLHttpRequest();
//解決瀏覽器在服務(wù)器端響應(yīng)由于沒(méi)有Text頭的時(shí)候可能無(wú)法工作的問(wèn)題
if(xmlhttprequest.overrideMimeType){
xmlhttprequest.overrideMimeType("text/xml");
}
}else if(window.ActiveXObject){
//IE6,IE5.5,IE5
alert("IE6,IE5.5,IE5");
var activexName =["MSXML2.XMLHTTP","Microsoft.XMLHTTP"];
for (var n=0;n
擴(kuò)展問(wèn)題
1.瀏覽器緩存
2.中文亂碼
3.跨域訪問(wèn)
對(duì)于問(wèn)題1、問(wèn)題3都可以通過(guò)更改url地址的方法得以解決。問(wèn)題1可在url地址尾添加時(shí)間戳,問(wèn)題3通過(guò)代理方式進(jìn)行解決。只需在send()中的第三步執(zhí)行前添加相應(yīng)判斷即可:
//解決緩存的轉(zhuǎn)換:增加時(shí)間戳
if(url.indexOf("?") >= 0 ){
url = url + "&t=" + (new Date())。valueOf();
} else {
url = url + "?t=" + (new Date())。valueOf();
}
//解決跨域的問(wèn)題
if(url.indexOf("http://") >= 0) {
url.replace("?","&");
url = "Proxy?url=" + url;
}
問(wèn)題3對(duì)應(yīng)代理服務(wù)端實(shí)現(xiàn):
/**
* Handles the HTTP GET method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//獲取參數(shù),最后得到請(qǐng)求url地址類(lèi)似于:url = http://192.168…/AJAX/AJAXServer?aa=11&bb=22&cc=33
StringBuilder url = new StringBuilder();
url.append(request.getParameter("url"));
//獲取訪問(wèn)的跨域地址url = http://192.168…/AJAX/AJAXServer
Enumeration enu = request.getParameterNames();
boolean flag = false; //定義標(biāo)志變量,表示是否為拼接的第一個(gè)參數(shù)
while(enu.hasMoreElements()){
String paramName = (String) enu.nextElement();
if(!paramName.equals("url")){
String paramValue = request.getParameter(paramName);
paramValue = URLEncoder.encode(paramValue,"utf-8");
if(!flag){
url.append("?")。append(paramName)。append("=")。append(paramValue);
flag = true;
} else {
url.append("&")。append(paramName)。append("=")。append(paramValue);
}
}
}
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
if(url != null && url.length() > 0){
URL connectionUrl = new URL(url.toString());
BufferedReader reader = new BufferedReader(new InputStreamReader(connectionUrl.openStream(),"utf-8"));
以上就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- Ajax xmlHttpRequest的status的值的含義
- AJAX中同時(shí)發(fā)送多個(gè)請(qǐng)求XMLHttpRequest對(duì)象處理方法
- 解析ajax核心XMLHTTPRequest對(duì)象的創(chuàng)建與瀏覽器的兼容問(wèn)題
- 如何用ajax來(lái)創(chuàng)建一個(gè)XMLHttpRequest對(duì)象
- Ajax通訊原理XMLHttpRequest
- ajax 入門(mén)基礎(chǔ)之 XMLHttpRequest對(duì)象總結(jié)
- AJAX入門(mén)之XMLHttpRequest慨述
- AJAX(XMLHttpRequest.status)狀態(tài)碼
- XMLHttpRequest對(duì)象_Ajax異步請(qǐng)求重點(diǎn)(推薦)
- AJAX XMLHttpRequest對(duì)象詳解
- 不使用XMLHttpRequest對(duì)象實(shí)現(xiàn)Ajax效果的方法小結(jié)
相關(guān)文章
AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07AJAX實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作詳解【java后臺(tái)】
這篇文章主要介紹了AJAX實(shí)現(xiàn)數(shù)據(jù)的增刪改查操作,結(jié)合實(shí)例形式詳細(xì)分析了ajax結(jié)合java后臺(tái)實(shí)現(xiàn)數(shù)據(jù)庫(kù)增刪改查相關(guān)操作技巧,需要的朋友可以參考下2020-06-06ajax異步傳值及后端接收參數(shù)的多種方式小結(jié)
這篇文章主要介紹了ajax異步傳值及后端接收參數(shù)的多種方式小結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11Ajax 動(dòng)態(tài)載入html頁(yè)面后不能執(zhí)行其中的js快速解決方法
這篇文章主要介紹了Ajax 動(dòng)態(tài)載入html頁(yè)面后不能執(zhí)行其中的js快速解決方法,需要的朋友可以參考下2018-06-06Json數(shù)據(jù)異步綁定到界面的Table并且自動(dòng)刷新原理及代碼
做Winform習(xí)慣了,大家都習(xí)慣設(shè)置datasource這樣的寫(xiě)法,今天就先從這個(gè)updatepanel加timer實(shí)現(xiàn)頁(yè)面自動(dòng)刷新這個(gè)例子來(lái)下手吧,感興趣的朋友可以了解下,或許對(duì)你學(xué)習(xí)ajax有所幫助2013-02-02你的jquery ajax無(wú)效和你的jquery引入路徑有關(guān)
當(dāng)你發(fā)現(xiàn)你的jquery ajax無(wú)效的時(shí)候,不妨使用 fire bug調(diào)試一下,這時(shí)你會(huì)發(fā)現(xiàn),提示"$"無(wú)效,為什么會(huì)有這種提示呢?可能是你引入jquery.js的路徑有問(wèn)題2013-06-06使用FormData進(jìn)行Ajax請(qǐng)求上傳文件的實(shí)例代碼
這篇文章主要介紹了使用FormData進(jìn)行Ajax請(qǐng)求上傳文件的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08使用jQuery簡(jiǎn)化Ajax開(kāi)發(fā)
jQuery 是一個(gè)JavaScript 庫(kù),它有助于簡(jiǎn)化 JavaScript™ 以及 Asynchronous JavaScript + XML (Ajax) 編程。與類(lèi)似的 JavaScript 庫(kù)不同,jQuery 具有獨(dú)特的基本原理,可以簡(jiǎn)潔地表示常見(jiàn)的復(fù)雜代碼。2009-11-11Servlet+Ajax實(shí)現(xiàn)智能搜索框智能提示功能
這篇文章主要介紹了Servlet+Ajax實(shí)現(xiàn)智能搜索框智能提示功能,需要的朋友可以參考下2017-04-04利用 Linq+Jquery+Ajax 實(shí)現(xiàn)異步分頁(yè)功能可簡(jiǎn)化帶寬壓力
網(wǎng)上的分頁(yè)方法甚多,但都太過(guò)于消耗帶寬,所以我想到了用Ajax來(lái)分頁(yè),利用返回的Json來(lái)處理返回的數(shù)據(jù),大大簡(jiǎn)化了帶寬的壓力2014-05-05