婷婷久久综合九色综合,欧美成色婷婷在线观看视频,偷窥视频一区,欧美日本一道道一区二区

<tt id="bu9ss"></tt>
  • <span id="bu9ss"></span>
  • <pre id="bu9ss"><tt id="bu9ss"></tt></pre>
    <label id="bu9ss"></label>

    當前位置:首頁 >  站長 >  編程技術(shù) >  正文

    Ajax工作原理及優(yōu)缺點實例解析

     2020-11-03 13:32  來源: 腳本之家   我來投稿 撤稿糾錯

      阿里云優(yōu)惠券 先領(lǐng)券再下單

    這篇文章主要介紹了Ajax工作原理及優(yōu)缺點實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

    1.Ajax是什么?

    全稱是 asynchronous javascript and xml,是已有技術(shù)的組合,主要用來實現(xiàn)客戶端與服務(wù)器端的異步通信效果(無需重新加載整個網(wǎng)頁的情況下),實現(xiàn)頁面的局部刷新。

    通過在后臺與服務(wù)器進行少量數(shù)據(jù)交換,AJAX 可以使網(wǎng)頁實現(xiàn)異步更新,用于創(chuàng)建快速動態(tài)網(wǎng)頁。

    早期的瀏覽器并不能原生支持 ajax,可以使用隱藏幀(iframe)方式變相實現(xiàn)異步效果,后來的瀏覽器提供了對 ajax 的原生支持。

    2. Ajax的工作原理

    使用 Ajax 原生方式發(fā)送請求主要通過 XMLHttpRequest(IE7+、Firefox、Chrome、Safari 以及Opera) 、ActiveXObject(IE5 和 IE6)對象實現(xiàn)異步通信效果。

    創(chuàng)建XMLHttpRequest對象:

    var xhr;
    if (window.XMLHttpRequest)
    {
      // IE7+, Firefox, Chrome, Opera, Safari 瀏覽器執(zhí)行代碼
      xhr=new XMLHttpRequest();
    }
    else
    {
      // IE6, IE5 瀏覽器執(zhí)行代碼
      xhr=new ActiveXObject("Microsoft.XMLHTTP");
    }

    向服務(wù)器發(fā)送請求:使用 XMLHttpRequest 對象的 open() 和 send() 方法

    //通過 GET 方法發(fā)送信息,請向 URL 添加信息
    xhr.open("GET","/try/ajax/demo_get2.php?fname=Henry&lname=Ford",true);
    xhr.send();

    //像 HTML 表單那樣 POST 數(shù)據(jù),使用 setRequestHeader() 來添加 HTTP 頭
    xhr.open("POST","/try/ajax/demo_post2.php",true);
    xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    xhr.send("fname=Henry&lname=Ford");

    //當使用 async=true 時,需規(guī)定在響應(yīng)處于 onreadystatechange 事件中的就緒狀態(tài)時執(zhí)行的函數(shù)
    xhr.onreadystatechange=function()
    {
      if (xhr.readyState==4 && xhr.status==200)
      {
        document.getElementById("myDiv").innerHTML=xhr.responseText;
      }
    }
    xhr.open("GET","/try/ajax/ajax_info.txt",true);
    xhr.send();

    //當您使用 async=false 時,把代碼放到 send() 語句后面即可,不推薦使用
    xhr.open("GET","/try/ajax/ajax_info.txt",false);
    xhr.send();
    document.getElementById("myDiv").innerHTML=xhr.responseText;

    使用GET還是POST?

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

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

    然而,在以下情況中,請使用 POST 請求:

    無法使用緩存文件(更新服務(wù)器上的文件或數(shù)據(jù)庫)

    向服務(wù)器發(fā)送大量數(shù)據(jù)(POST 沒有數(shù)據(jù)量限制)

    發(fā)送包含未知字符的用戶輸入時,POST 比 GET 更穩(wěn)定也更可靠

    //來自服務(wù)器的響應(yīng)并非 XML,使用 responseText 屬性,返回字符串形式的響應(yīng)
    document.getElementById("myDiv").innerHTML=xhr.responseText;

    //來自服務(wù)器的響應(yīng)是 XML,而且需要作為 XML 對象進行解析,使用 responseXML 屬性,請求 cd_catalog.xml 文件,并解析響應(yīng)
    xmlDoc=xhr.responseXML;
    txt="";
    x=xmlDoc.getElementsByTagName("ARTIST");
    for (i=0;i<x.length;i++)
    {
      txt=txt + x[i].childNodes[0].nodeValue + "<br>";
    }
    document.getElementById("myDiv").innerHTML=txt;

    onreadystatechange事件:當請求被發(fā)送到服務(wù)器時,我們需要執(zhí)行一些基于響應(yīng)的任務(wù)。每當 readyState 改變時,就會觸發(fā) onreadystatechange 事件。

    //當 readyState 等于 4 且狀態(tài)為 200 時,表示響應(yīng)已就緒
    xhr.onreadystatechange=function()
    {
      if (xhr.readyState==4 && xhr.status==200)
      {
        document.getElementById("myDiv").innerHTML=xhr.responseText;
      }
    }
    //如果存在多個 AJAX 任務(wù),那么應(yīng)該為創(chuàng)建 XMLHttpRequest 對象編寫一個標準的函數(shù),并為每個 AJAX 任務(wù)調(diào)用該函數(shù)。該函數(shù)調(diào)用應(yīng)該包含 URL 以及發(fā)生 onreadystatechange 事件時執(zhí)行的任務(wù)(每次調(diào)用可能不盡相同)
    function myFunction()
    {
      loadXMLDoc("/try/ajax/ajax_info.txt",function()
      {
        if (xmlhttp.readyState==4 && xmlhttp.status==200)
        {
          document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
        }
      });
    }

    xhr.readyState的值及解釋:

    0:請求未初始化(還沒有調(diào)用 open())。

    1:請求已經(jīng)建立,但是還沒有發(fā)送(還沒有調(diào)用 send())。

    2:請求已發(fā)送,正在處理中(通?,F(xiàn)在可以從響應(yīng)中獲取內(nèi)容頭)。

    3:請求在處理中;通常響應(yīng)中已有部分數(shù)據(jù)可用了,但是服務(wù)器還沒有完成響應(yīng)的生成。

    4:響應(yīng)已完成;您可以獲取并使用服務(wù)器的響應(yīng)了。

    xhr.status的值及解釋:

    100——客戶必須繼續(xù)發(fā)出請求

    101——客戶要求服務(wù)器根據(jù)請求轉(zhuǎn)換HTTP協(xié)議版本

    200——交易成功

    201——提示知道新文件的URL

    202——接受和處理、但處理未完成

    203——返回信息不確定或不完整

    204——請求收到,但返回信息為空

    205——服務(wù)器完成了請求,用戶代理必須復位當前已經(jīng)瀏覽過的文件

    206——服務(wù)器已經(jīng)完成了部分用戶的GET請求

    300——請求的資源可在多處得到

    301——刪除請求數(shù)據(jù)

    302——在其他地址發(fā)現(xiàn)了請求數(shù)據(jù)

    303——建議客戶訪問其他URL或訪問方式

    304——客戶端已經(jīng)執(zhí)行了GET,但文件未變化

    305——請求的資源必須從服務(wù)器指定的地址得到

    306——前一版本HTTP中使用的代碼,現(xiàn)行版本中不再使用

    307——申明請求的資源臨時性刪除

    400——錯誤請求,如語法錯誤

    401——請求授權(quán)失敗

    402——保留有效ChargeTo頭響應(yīng)

    403——請求不允許

    404——沒有發(fā)現(xiàn)文件、查詢或URl

    405——用戶在Request-Line字段定義的方法不允許

    406——根據(jù)用戶發(fā)送的Accept拖,請求資源不可訪問

    407——類似401,用戶必須首先在代理服務(wù)器上得到授權(quán)

    408——客戶端沒有在用戶指定的餓時間內(nèi)完成請求

    409——對當前資源狀態(tài),請求不能完成

    410——服務(wù)器上不再有此資源且無進一步的參考地址

    411——服務(wù)器拒絕用戶定義的Content-Length屬性請求

    412——一個或多個請求頭字段在當前請求中錯誤

    413——請求的資源大于服務(wù)器允許的大小

    414——請求的資源URL長于服務(wù)器允許的長度

    415——請求資源不支持請求項目格式

    416——請求中包含Range請求頭字段,在當前請求資源范圍內(nèi)沒有range指示值,請求也不包含If-Range請求頭字段

    417——服務(wù)器不滿足請求Expect頭字段指定的期望值,如果是代理服務(wù)器,可能是下一級服務(wù)器不能滿足請求

    500——服務(wù)器產(chǎn)生內(nèi)部錯誤

    501——服務(wù)器不支持請求的函數(shù)

    502——服務(wù)器暫時不可用,有時是為了防止發(fā)生系統(tǒng)過載

    503——服務(wù)器過載或暫停維修

    504——關(guān)口過載,服務(wù)器使用另一個關(guān)口或服務(wù)來響應(yīng)用戶,等待時間設(shè)定值較長

    505——服務(wù)器不支持或拒絕支請求頭中指定的HTTP版本

    1xx:信息響應(yīng)類,表示接收到請求并且繼續(xù)處理

    2xx:處理成功響應(yīng)類,表示動作被成功接收、理解和接受

    3xx:重定向響應(yīng)類,為了完成指定的動作,必須接受進一步處理

    4xx:客戶端錯誤,客戶請求包含語法錯誤或者是不能正確執(zhí)行

    5xx:服務(wù)端錯誤,服務(wù)器不能正確執(zhí)行一個正確的請求

    3. Ajax的優(yōu)缺點

    優(yōu)點: 1.無刷新更新數(shù)據(jù):在不刷新整個頁面的情況下維持與服務(wù)器通信

    2.異步與服務(wù)器通信:使用異步的方式與服務(wù)器通信,不打斷用戶的操作

    3.前端與后端負載均衡:將一些后端的工作移到前端,減少服務(wù)器與帶寬的負擔

    4.基于規(guī)范被廣泛支持:不需要下載瀏覽器插件或者小程序,但需要客戶允許JavaScript在瀏覽器上執(zhí)行。

    5.界面與應(yīng)用分離:Ajax使得界面與應(yīng)用分離,也就是數(shù)據(jù)與呈現(xiàn)分離

    缺點: 1.Ajax不支持Back與History功能,即對瀏覽器機制的破壞:在動態(tài)更新頁面的情況下,用戶無法回到前一頁的頁面狀態(tài),因為瀏覽器僅能記憶歷史紀錄中的靜態(tài)頁面

    2.安全問題:AJAX技術(shù)給用戶帶來很好的用戶體驗的同時也對IT企業(yè)帶來了新的安全威脅,Ajax技術(shù)就如同對企業(yè)數(shù)據(jù)建立了一個直接通道。這使得開發(fā)者在不經(jīng)意間會暴露比以前更多的數(shù)據(jù)和服務(wù)器邏輯。ajax的邏輯可以對客戶端的安全掃描技術(shù)隱藏起來,允許黑客從遠端服務(wù)器上建立新的攻擊。還有ajax也難以避免一些已知的安全弱點,諸如跨站點腳步攻擊、SQL注入攻擊和基于credentials的安全漏洞等。

    3.對搜索引擎支持較弱:如果使用不當,AJAX會增大網(wǎng)絡(luò)數(shù)據(jù)的流量,從而降低整個系統(tǒng)的性能。解決的辦法:可以先用服務(wù)器渲染。

    4.破壞程序的異常處理機制

    5.違背URL與資源定位的初衷

    6.不能很好地支持移動設(shè)備

    7.客戶端肥大,太多客戶段代碼造成開發(fā)上的成本

    4.應(yīng)用場景

    1.動態(tài)加載數(shù)據(jù),按需取得數(shù)據(jù)。【樹形菜單、聯(lián)動菜單.../省市聯(lián)動】

    2.改善用戶體驗?!据斎雰?nèi)容前提示、帶進度條文件上傳...】

    3.電子商務(wù)應(yīng)用?!举徫镘?、郵件訂閱...】

    4.訪問第三方服務(wù)?!驹L問搜索服務(wù)、rss閱讀器】

    5.數(shù)據(jù)的布局刷新

    不適用于搜索,基本的導航,替換大量的文本,部分簡單的表單

    以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

    來源:腳本之家

    鏈接:https://www.jb51.net/article/194703.htm

    申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

    相關(guān)標簽
    ajax

    相關(guān)文章

    • Ajax實現(xiàn)頁面無刷新留言效果

      這篇文章主要為大家詳細介紹了Ajax實現(xiàn)頁面無刷新留言效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

      標簽:
      ajax
    • AJAX檢測用戶名是否存在的方法

      這篇文章主要為大家詳細介紹了AJAX檢測用戶名是否存在,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

      標簽:
      ajax
    • 使用AJAX 包含正則表達式 驗證用戶登錄的步驟

      這篇文章主要介紹了使用AJAX(包含正則表達式)驗證用戶登錄的步驟,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

      標簽:
      ajax
    • ajax使用formdata上傳文件流

      這篇文章主要為大家詳細介紹了ajax使用formdata上傳文件流,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

      標簽:
      ajax
    • Spring MVC+ajax進行信息驗證的方法

      AJAX不是新的編程語言,而是一種使用現(xiàn)有標準的新方法。這篇文章主要介紹了SpringMVC+ajax進行信息驗證,需要的朋友可以參考下

      標簽:
      ajax

    熱門排行

    信息推薦