4、原生javascript封裝ajax————呱呱二號

來源:互聯網
上載者:User

標籤:json   ==   www   active   one   stat   code   ajax   XML   

//添加事件處理
function addEvent(obj, type, fn) {
  if (obj.addEventListener) {
    obj.addEventListener(type, fn, false);
  } else if (obj.attachEvent) {
    obj.attachEvent(‘on‘ + type, function () {
      fn.call(obj);
    });
  }
}
//移除事件處理
function removeEvent(obj, type, fn) {
  if (obj.removeEventListener) {
    obj.removeEventListener(type, fn, false);
  } else if (obj.detachEvent) {
    obj.detachEvent(‘on‘ + type, fn);
  }
}

//封裝ajax
function createXHR(){
  if(XMLHttpRequest){
    return new XMLHttpRequest();
  }else{
    return new ActiveXObject(‘Microsoft.XMLHTTP‘);
  }
}

//名值對轉換為字串
function params(data){
  var arr = [];
  for(var i in data){
    arr.push(encodeURIComponent(i) + ‘=‘ + encodeURIComponent(data[i]));
  }
  return arr.join(‘&‘);
}

function ajax(obj){
  var xhr = createXHR();
  obj.method = obj.method.toUpperCase()
  obj.url = obj.url + ‘?rand=‘ + Math.random();
  obj.data = params(obj.data);
  if(obj.method === ‘GET‘){
    obj.url += obj.url.indexOf(‘?‘) == -1? ‘?‘ + obj.data : ‘&‘ + obj.data;
  }
  if(obj.async === true){
    xhr.onreadystatechange = function(){
      if(xhr.readyState == 4){
        callback();
      }
    };
  }
  xhr.open(obj.method,obj.url,obj.async);
  if(obj.method === "POST"){
    xhr.setRequestHeader(‘Content-Type‘,‘application/x-www-form-urlencoded‘);
    xhr.send(obj.data);
  }else{
    xhr.send(null);
  }
  if(obj.async === false){
    callback();
  }
  function callback(){
    if(xhr.status == 200){
      obj.success(xhr.responseText);
    }else{
      alert(‘擷取資料錯誤!錯誤碼:‘ + xhr.status + ‘,錯誤資訊:‘ . xhr.statusText);
    }
  }
}


//調用ajax
addEvent(document,‘click‘,function(){
ajax({
  method: ‘get‘,
  url: ‘demo.php‘,
  data: {
    ‘name‘: ‘lee‘
  },
  success: function(text){
    var result = JSON.parse(text);
  },
  async: true
  });
});

 

4、原生javascript封裝ajax————呱呱二號

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.