主頁 > 知識庫 > Ajax核心XMLHttpRequest總結(jié)

Ajax核心XMLHttpRequest總結(jié)

熱門標(biāo)簽:目標(biāo)三維地圖標(biāo)注 徐州電銷卡外呼系統(tǒng)供應(yīng)商 科智聯(lián)智能電銷機(jī)器人 襄陽外呼系統(tǒng)接口 上海浦東百度地圖標(biāo)注中心注冊 百靈鳥 青海醫(yī)療智能外呼系統(tǒng)怎么樣 外呼系統(tǒng)獲取客戶手機(jī)號 老虎郵局地圖標(biāo)注點(diǎn)

Ajax:即"Asynchronous JavaScript and XML"(異步JavaScript和XML),一門綜合性的技術(shù):運(yùn)用JavaScript對象XMLHttpRequest進(jìn)行異步數(shù)據(jù)交換;JavaScript操作DOM實(shí)現(xiàn)動態(tài)效果;運(yùn)用XHTML+CSS表達(dá)信息;XML和XSLT操作數(shù)據(jù)。此篇文章重點(diǎn)介紹使用XMLHttpRequest對象與服務(wù)器端進(jìn)行異步數(shù)據(jù)交換。

    使用方法 
    XMLHttpRequest五步使用法:

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

    1.創(chuàng)建對象;
    2.注冊回調(diào)函數(shù);
    3.使用open方法設(shè)置和服務(wù)器交互的基本信息;
    4.設(shè)置發(fā)送的數(shù)據(jù),開始和服務(wù)器端交互;
    5.實(shí)現(xiàn)回調(diào)函數(shù)。

    由于每次應(yīng)用XMLHttpRequest對象時,都要進(jìn)行五步操作,因此,可將該對象的使用封裝為js文件中,傳遞部分參數(shù)使用其方法就可以完成相應(yīng)功能,實(shí)現(xiàn)如下:

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

    //使用封裝方法人員只提供http的請求,url地址,數(shù)據(jù),成功和失敗的回調(diào)的方法
    //1.定義XMLHttpRequest對象的構(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)由于沒有Text頭的時候可能無法工作的問題
    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ò)展問題

    1.瀏覽器緩存
    2.中文亂碼
    3.跨域訪問

    對于問題1、問題3都可以通過更改url地址的方法得以解決。問題1可在url地址尾添加時間戳,問題3通過代理方式進(jìn)行解決。只需在send()中的第三步執(zhí)行前添加相應(yīng)判斷即可:

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

    //解決緩存的轉(zhuǎn)換:增加時間戳
    if(url.indexOf("?") >= 0 ){
    url = url + "t=" + (new Date())。valueOf();
    } else {
    url = url + "?t=" + (new Date())。valueOf();
    }
    //解決跨域的問題
    if(url.indexOf("http://") >= 0) {
    url.replace("?","");
    url = "Proxy?url=" + url;
    }

    問題3對應(yīng)代理服務(wù)端實(shí)現(xiàn):

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

    /**
    * 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ù),最后得到請求url地址類似于:url = http://192.168…/AJAX/AJAXServer?aa=11bb=22cc=33
    StringBuilder url = new StringBuilder();
    url.append(request.getParameter("url"));
    //獲取訪問的跨域地址url = http://192.168…/AJAX/AJAXServer
    Enumeration enu = request.getParameterNames();
    boolean flag = false;       //定義標(biāo)志變量,表示是否為拼接的第一個參數(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"));

以上就是本文的全部內(nèi)容了,希望大家能夠喜歡。

您可能感興趣的文章:
  • Ajax xmlHttpRequest的status的值的含義
  • AJAX中同時發(fā)送多個請求XMLHttpRequest對象處理方法
  • 解析ajax核心XMLHTTPRequest對象的創(chuàng)建與瀏覽器的兼容問題
  • 如何用ajax來創(chuàng)建一個XMLHttpRequest對象
  • Ajax通訊原理XMLHttpRequest
  • ajax 入門基礎(chǔ)之 XMLHttpRequest對象總結(jié)
  • AJAX入門之XMLHttpRequest慨述
  • AJAX(XMLHttpRequest.status)狀態(tài)碼
  • XMLHttpRequest對象_Ajax異步請求重點(diǎn)(推薦)
  • AJAX XMLHttpRequest對象詳解
  • 不使用XMLHttpRequest對象實(shí)現(xiàn)Ajax效果的方法小結(jié)

標(biāo)簽:紅河 股票 咸寧 佛山 辛集 揭陽 商洛 荊州

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