成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Ajax工作原理及優缺點實例解析

瀏覽:142日期:2022-06-11 16:43:10

1.Ajax是什么?

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

通過在后臺與服務器進行少量數據交換,AJAX 可以使網頁實現異步更新,用于創建快速動態網頁。

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

2. Ajax的工作原理

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

創建XMLHttpRequest對象:

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

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

//通過 GET 方法發送信息,請向 URL 添加信息xhr.open("GET","/try/ajax/demo_get2.php?fname=Henry&lname=Ford",true);xhr.send();//像 HTML 表單那樣 POST 數據,使用 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 時,需規定在響應處于 onreadystatechange 事件中的就緒狀態時執行的函數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 請求:

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

//來自服務器的響應并非 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事件:當請求被發送到服務器時,我們需要執行一些基于響應的任務。每當 readyState 改變時,就會觸發 onreadystatechange 事件。

//當 readyState 等于 4 且狀態為 200 時,表示響應已就緒xhr.onreadystatechange=function(){  if (xhr.readyState==4 && xhr.status==200)  {    document.getElementById("myDiv").innerHTML=xhr.responseText;  }}//如果存在多個 AJAX 任務,那么應該為創建 XMLHttpRequest 對象編寫一個標準的函數,并為每個 AJAX 任務調用該函數。該函數調用應該包含 URL 以及發生 onreadystatechange 事件時執行的任務(每次調用可能不盡相同)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:請求未初始化(還沒有調用 open())。

1:請求已經建立,但是還沒有發送(還沒有調用 send())。

2:請求已發送,正在處理中(通常現在可以從響應中獲取內容頭)。

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

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

xhr.status的值及解釋:

100——客戶必須繼續發出請求

101——客戶要求服務器根據請求轉換HTTP協議版本

200——交易成功

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

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

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

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

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

206——服務器已經完成了部分用戶的GET請求

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

301——刪除請求數據

302——在其他地址發現了請求數據

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

304——客戶端已經執行了GET,但文件未變化

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

306——前一版本HTTP中使用的代碼,現行版本中不再使用

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

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

401——請求授權失敗

402——保留有效ChargeTo頭響應

403——請求不允許

404——沒有發現文件、查詢或URl

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

406——根據用戶發送的Accept拖,請求資源不可訪問

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

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

409——對當前資源狀態,請求不能完成

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

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

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

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

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

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

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

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

500——服務器產生內部錯誤

501——服務器不支持請求的函數

502——服務器暫時不可用,有時是為了防止發生系統過載

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

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

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

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

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

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

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

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

3. Ajax的優缺點

優點:1.無刷新更新數據:在不刷新整個頁面的情況下維持與服務器通信

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

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

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

   5.界面與應用分離:Ajax使得界面與應用分離,也就是數據與呈現分離

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

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

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

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

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

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

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

4.應用場景

1.動態加載數據,按需取得數據。【樹形菜單、聯動菜單.../省市聯動】

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

3.電子商務應用。【購物車、郵件訂閱...】

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

5.數據的布局刷新

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

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

標簽: Ajax
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
中文字幕一区二区三区不卡在线| 99综合精品| 欧美日韩在线高清| 91麻豆精品国产91久久久资源速度 | 午夜婷婷国产麻豆精品| 99在线热播精品免费| 欧美理论在线播放| 欧美a级理论片| 亚洲欧美日本视频在线观看| 亚洲欧洲日韩av| 欧美日韩岛国| 国产亚洲va综合人人澡精品 | 国内精品国语自产拍在线观看| 欧美卡1卡2卡| 奇米亚洲午夜久久精品| 国产精品久久久久久模特| 亚洲美腿欧美偷拍| 亚洲动漫精品| 亚洲视频你懂的| 亚洲国内在线| 亚洲欧美另类小说| 91视频免费播放| 亚洲国产精品一区在线观看不卡 | 国产精一品亚洲二区在线视频| 色8久久人人97超碰香蕉987| 亚洲成在人线免费| 久久久久久黄| 日韩av在线发布| 91国偷自产一区二区三区观看| 日本特黄久久久高潮| 一本到高清视频免费精品| 丝袜美腿亚洲一区二区图片| 欧美亚洲自偷自偷| 香港成人在线视频| 免费在线观看一区二区| 亚洲成av人综合在线观看| 国产日韩欧美| 洋洋av久久久久久久一区| 亚洲高清免费| 一区二区三区欧美日韩| 免费久久久一本精品久久区| 欧美精品日韩一区| 国产欧美一区视频| 东方欧美亚洲色图在线| 日韩欧美综合一区| 国产91丝袜在线播放0| 日韩欧美在线影院| 不卡影院免费观看| 久久久蜜桃精品| 欧美日韩喷水| 国产精品天干天干在观线| 国产精品v欧美精品v日韩| 亚洲国产一二三| 91精品婷婷国产综合久久性色 | 国产乱色国产精品免费视频| 欧美一区二区三区在| 成人精品视频一区二区三区尤物| 久久久亚洲精品一区二区三区| 国内精品99| 一区二区三区在线视频免费| 美女诱惑黄网站一区| 麻豆精品视频在线观看免费| 欧美日韩高清一区二区三区| 成人综合婷婷国产精品久久蜜臀 | 亚洲综合在线第一页| 国产婷婷精品| 美女一区二区三区在线观看| 欧美成人性战久久| 亚洲高清自拍| 蜜桃一区二区三区在线观看| 日韩欧美www| 亚洲激情专区| 精一区二区三区| 久久―日本道色综合久久| 国产视频在线观看一区| 激情综合网av| 亚洲国产精品成人综合色在线婷婷| 国产女主播一区二区| 国产精品一区二区不卡| 国产精品久久网站| 欧美吞精做爰啪啪高潮| 欧美在线资源| 亚洲国产精品一区二区久久| 日韩亚洲电影在线| 99精品视频网| 国产呦萝稀缺另类资源| 欧美三级视频在线播放| 99精品久久只有精品| 亚洲日本韩国一区| 国产精品亚洲不卡a| 国产麻豆精品视频| 国产午夜亚洲精品理论片色戒| 国产精品国产亚洲精品看不卡15| 一区二区三区国产精华| 欧美性猛交xxxx乱大交退制版| 99国产精品久久久久久久久久| 一区二区三区在线播| 日本久久电影网| 国产夫妻精品视频| 国产精品女上位| 欧美亚洲一级| 成人高清在线视频| 亚洲永久免费视频| 欧美日韩精品一区二区三区蜜桃 | 亚洲成人你懂的| 欧美高清激情brazzers| 91女神在线视频| 亚洲国产精品久久人人爱蜜臀| 在线看国产一区二区| 午夜视频精品| 奇米影视一区二区三区| 2024国产精品视频| 久久狠狠一本精品综合网| 粉嫩欧美一区二区三区高清影视| 国产精品久久久久久久久免费丝袜 | 久久久天堂av| 午夜在线播放视频欧美| 国产成人丝袜美腿| 亚洲精品国久久99热| 9191精品国产综合久久久久久| 99国产精品久久久久老师| 久久国产麻豆精品| 国产精品成人免费在线| 欧美三级日本三级少妇99| 黄色成人在线网址| 久久精品国产在热久久| 国产精品久久久久久久久久久免费看 | 天堂一区二区在线| 26uuu国产电影一区二区| 国产精品免费在线| 国产91精品在线观看| 亚洲一区二区黄色| 精品国产伦一区二区三区观看方式 | www成人在线观看| 亚洲免费一区二区| 91免费看视频| 国产99久久久精品| 亚洲欧洲日产国码二区| 乱码第一页成人| 97se亚洲国产综合自在线不卡| 午夜精品视频在线观看| 久久久一区二区三区捆绑**| 夜久久久久久| 91啪九色porn原创视频在线观看| 婷婷一区二区三区| 国产精品情趣视频| 欧美高清www午色夜在线视频| 在线一区免费观看| 91视视频在线观看入口直接观看www | 国产日韩欧美一区二区三区综合| 国产欧美日韩不卡| 欧美亚洲国产bt| 亚洲黄色免费| 国产·精品毛片| 日本在线观看不卡视频| 亚洲欧洲成人精品av97| 538prom精品视频线放| 久久性天堂网| 影音先锋在线一区| youjizz国产精品| 老色鬼精品视频在线观看播放| 国产精品乱码人人做人人爱| 欧美日韩精品一区二区三区| 国产亚洲亚洲| 亚洲欧美综合国产精品一区| 国产精品一区在线观看你懂的| 污片在线观看一区二区| 国产精品久久99| 国产日产欧美一区| 日韩免费看网站| 欧美日韩亚洲另类| 久久综合图片| 国产农村妇女毛片精品久久莱园子| 伊人久久亚洲美女图片| 91视频xxxx| 成人免费毛片高清视频| 色先锋资源久久综合| 欧美午夜片在线观看| 精品1区2区3区4区| 国产精品88av| 日韩综合小视频| 一区二区三区中文在线| 国产亚洲综合色| 日韩一区二区三区在线| 欧美调教femdomvk| 噜噜噜躁狠狠躁狠狠精品视频| 一区免费视频| 欧美一区二区视频在线| 国产传媒日韩欧美成人| 免费国产亚洲视频| 亚洲在线视频网站| 亚洲国产一区视频| 国产原创一区二区| 亚洲免费资源在线播放| 亚洲三级小视频| 国产精品色在线| 中文字幕精品三区| 国产欧美日韩激情| 久久精品综合网| 国产欧美一区二区在线观看|