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

1.ajax是什么?

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

通過在后臺與服務器進行少量數(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");
}

向服務器發(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ī)定在響應處于 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 請求:

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

//來自服務器的響應并非 xml,使用 responsetext 屬性,返回字符串形式的響應
document.getelementbyid("mydiv").innerhtml=xhr.responsetext;

//來自服務器的響應是 xml,而且需要作為 xml 對象進行解析,使用 responsexml 屬性,請求 cd_catalog.xml 文件,并解析響應
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ā)送到服務器時,我們需要執(zhí)行一些基于響應的任務。每當 readystate 改變時,就會觸發(fā) onreadystatechange 事件。

//當 readystate 等于 4 且狀態(tài)為 200 時,表示響應已就緒
xhr.onreadystatechange=function()
{
  if (xhr.readystate==4 && xhr.status==200)
  {
    document.getelementbyid("mydiv").innerhtml=xhr.responsetext;
  }
}
//如果存在多個 ajax 任務,那么應該為創(chuàng)建 xmlhttprequest 對象編寫一個標準的函數(shù),并為每個 ajax 任務調(diào)用該函數(shù)。該函數(shù)調(diào)用應該包含 url 以及發(fā)生 onreadystatechange 事件時執(zhí)行的任務(每次調(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)在可以從響應中獲取內(nèi)容頭)。

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

4:響應已完成;您可以獲取并使用服務器的響應了。

xhr.status的值及解釋:

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

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

200——交易成功

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

401——請求授權失敗

402——保留有效chargeto頭響應

403——請求不允許

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

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

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

407——類似401,用戶必須首先在代理服務器上得到授權

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

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

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

411——服務器拒絕用戶定義的content-length屬性請求

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

413——請求的資源大于服務器允許的大小

414——請求的資源url長于服務器允許的長度

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

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

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

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

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

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

503——服務器過載或暫停維修

504——關口過載,服務器使用另一個關口或服務來響應用戶,等待時間設定值較長

505——服務器不支持或拒絕支請求頭中指定的http版本

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        6.不能很好地支持移動設備

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

4.應用場景

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

2.改善用戶體驗。【輸入內(nèi)容前提示、帶進度條文件上傳...】

3.電子商務應用?!举徫镘?、郵件訂閱...】

4.訪問第三方服務。【訪問搜索服務、rss閱讀器】

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

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

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

相關文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频