WebZero
1/9/2018 - 1:37 AM

原生js实现Ajax

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