首頁  >  文章  >  web前端  >  javascript如何實作ajax

javascript如何實作ajax

coldplay.xixi
coldplay.xixi原創
2021-04-30 11:08:474804瀏覽

javascript實作ajax的方法:首先將XMLHttpRequest物件用於在後台與伺服器交換資料;然後從伺服器取得資料;最後新增http頭,傳送訊息至伺服器時內容編碼類型。

javascript如何實作ajax

本教學操作環境:windows7系統、javascript1.8.5版,DELL G3電腦。

javascript實作ajax的方法:

var Ajax={
  get: function(url, fn) {
    // XMLHttpRequest对象用于在后台与服务器交换数据   
    var xhr = new XMLHttpRequest();            
    xhr.open('GET', url, true);
    xhr.onreadystatechange = function() {
      // readyState == 4说明请求已完成
      if (xhr.readyState == 4 && xhr.status == 200 || xhr.status == 304) { 
        // 从服务器获得数据 
        fn.call(this, xhr.responseText);  
      }
    };
    xhr.send();
  },
  // datat应为'a=a1&b=b1'这种字符串格式,在jq里如果data为对象会自动将对象转成这种字符串格式
  post: function (url, data, fn) {
    var xhr = new XMLHttpRequest();
    xhr.open("POST", url, true);
    // 添加http头,发送信息至服务器时内容编码类型
    xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");  
    xhr.onreadystatechange = function() {
      if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 304)) {
        fn.call(this, xhr.responseText);
      }
    };
    xhr.send(data);
  }
}

open(method, url, async) 方法需要三個參數:

  method:傳送請求所使用的方法(GET或POST);

與POST相比,GET更簡單也更快,並且在大部分情況下都能用;然而,在以下情況中,請使用POST請求:

無法使用快取檔案(更新伺服器上的檔案或資料庫)

傳送大量資料到伺服器(POST 沒有資料量限制)

傳送包含未知字元的使用者輸入時,POST 比GET 更穩定也更可靠

 url:規定伺服器端腳本的URL(該文件可以是任何類型的文件,例如.txt 和.xml,或伺服器腳本文件,例如.asp 和. php (在傳迴回應之前,能夠在伺服器上執行任務));

 async:規定應對請求進行非同步(true)或同步(false)處理;true是在等待伺服器回應時執行其他腳本,當回應就緒後對回應進行處理;false是等待伺服器回應再執行。

相關免費學習推薦:javascript影片教學

#

以上是javascript如何實作ajax的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn