欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

AJAX怎么實現(xiàn)異步和局部刷新

小編給大家分享一下AJAX怎么實現(xiàn)異步和局部刷新,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計制作、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的進賢網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

Overriew: onReadyStateChange被回調(diào)函數(shù)賦值,則能實現(xiàn)異步調(diào)用,回調(diào)函數(shù)直接操作DOM,則能實現(xiàn)局部刷新。那么XMLHttpRequest的onReadyStateChange如何知道服務(wù)ready了呢?狀態(tài)如何change了呢(觀察者模式)?則是通過客戶端對服務(wù)的狀態(tài)詢問(定期輪詢)所實現(xiàn)的。

詳解:

1. XMLHttpRequest 負責(zé)與服務(wù)器端的通訊,其內(nèi)部有很多重要的屬性:readyStatus=4,status=200等等。當XMLHttpRequest的整體狀態(tài)并且保證它已經(jīng)完成(readyStatus=4),即數(shù)據(jù)已經(jīng)發(fā)送完畢。然后根據(jù)服務(wù)器的設(shè)定詢問(類似于客戶端會輪詢服務(wù)器的返回狀態(tài),仍然是http短連接,并非長連接的服務(wù)器端push)請求狀態(tài),如果一切已經(jīng)就緒(status=200),那么就執(zhí)行需要的操作。

操作一般就是直接操作DOM,所以AJAX能做到所謂的“無刷新”用戶體驗。

document.getElementById("user1").innerHTML = "數(shù)據(jù)正在加載...";
      if (xmlhttp.status == 200) {
        document.write(xmlhttp.responseText);
      }

2. 那么在AJAX客戶端如何做到的異步呢?實際上就是Javascript的回調(diào)函數(shù)起的作用

提供一個回調(diào)JavaScript函數(shù),一旦服務(wù)器響應(yīng)可用,該函數(shù)就被執(zhí)行

業(yè)務(wù)函數(shù):

function castVote(rank) {
 var url = "/ajax-demo/static-article-ranking.html";
 var callback = processAjaxResponse;
 executeXhr(callback, url);
}
需要異步通訊的函數(shù): 


function executeXhr(callback, url) {
 // branch for native XMLHttpRequest object
 if (window.XMLHttpRequest) {
  req = new XMLHttpRequest();
  req.onreadystatechange = callback;
  req.open("GET", url, true);
  req.send()(null);
 } // branch for IE/Windows ActiveX version
 else if (window.ActiveXObject) {
  req = new ActiveXObject("Microsoft.XMLHTTP");
  if (req) {
   req.onreadystatechange = callback;
   req.open("GET", url, true);
   req.send()();
  }
 }
}
req.onreadystatechange = callback
req.open("GET", url, true)

第一行定義了JavaScript回調(diào)函數(shù),一旦響應(yīng)就緒它就自動執(zhí)行,而req.open()方法中所指定的“true”標志說明想要異步執(zhí)行該請求。

一旦服務(wù)器處理完XmlHttpRequest并返回給瀏覽器,使用req.onreadystatechange指派所設(shè)置的回調(diào)方法將被自動調(diào)用。

回調(diào)函數(shù):

function processAjaxResponse() {
 if (req.readyState == 4) {
  // only if "OK"
  if (req.status == 200) {
   document.getElementById("user1").innerHTML = req.responseText;
  } else {
   alert("There was a problem retrieving the XML data:
" + req.statusText);
  }
 }
}

以上是“AJAX怎么實現(xiàn)異步和局部刷新”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標題名稱:AJAX怎么實現(xiàn)異步和局部刷新
新聞來源:http://chinadenli.net/article36/gsjesg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站網(wǎng)站改版網(wǎng)站導(dǎo)航全網(wǎng)營銷推廣網(wǎng)頁設(shè)計公司云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)