亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用原生js寫ajax實例(推薦)

 更新時間:2017年05月31日 07:46:50   投稿:jingxian  
下面小編就為大家?guī)硪黄褂迷鷍s寫ajax實例(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

實例如下:

// 使用原生js 封裝ajax
// 兼容xhr對象
function createXHR(){
  if(typeof XMLHttpRequest != "undefined"){ // 非IE6瀏覽器
    return new XMLHttpRequest();
  }else if(typeof ActiveXObject != "undefined"){  // IE6瀏覽器
    var version = [
          "MSXML2.XMLHttp.6.0",
          "MSXML2.XMLHttp.3.0",
          "MSXML2.XMLHttp",
    ];
    for(var i = 0; i < version.length; i++){
      try{
        return new ActiveXObject(version[i]);
      }catch(e){
        //跳過
      }
    }
  }else{
    throw new Error("您的系統(tǒng)或瀏覽器不支持XHR對象!");
  }
}
// 轉(zhuǎn)義字符
function params(data){
  var arr = [];
  for(var i in data){
    arr.push(encodeURIComponent(i) + "=" + encodeURIComponent(data[i]));
  }
  return arr.join("&");
}
// 封裝ajax
function ga_ajax(obj){
  var xhr = createXHR();
  obj.url = obj.url + "?rand=" + Math.random(); // 清除緩存
  obj.data = params(obj.data);   // 轉(zhuǎn)義字符串
  if(obj.method === "get"){   // 判斷使用的是否是get方式發(fā)送
    obj.url += obj.url.indexOf("?") == "-1" ? "?" + obj.data : "&" + obj.data;
  }
  // 異步
  if(obj.async === true){
    // 異步的時候需要觸發(fā)onreadystatechange事件
    xhr.onreadystatechange = function(){
      // 執(zhí)行完成
      if(xhr.readyState == 4){
        callBack();
      }
    }
  }
  xhr.open(obj.method,obj.url,obj.async); // false是同步 true是異步 // "demo.php?rand="+Math.random()+"&name=ga&ga",
  if(obj.method === "post"){
    xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
    xhr.send(obj.data);
  }else{
    xhr.send(null);
  }
  // xhr.abort(); // 取消異步請求
  // 同步
  if(obj.async === false){
    callBack();
  }
  // 返回數(shù)據(jù)
  function callBack(){
    // 判斷是否返回正確
    if(xhr.status == 200){
      obj.success(xhr.responseText);
    }else{
      obj.Error("獲取數(shù)據(jù)失敗,錯誤代號為:"+xhr.status+"錯誤信息為:"+xhr.statusText);
    }
  }
}

var html = document.getElementsByTagName("html")[0];
html.onclick = function(){
  ga_ajax({
    "method" : "post",
    "url" : "demo.php",
    "data" : {
      "name" : "gao",
      "age" : 100,
      "num" : "12346&598"
    },
    "success" : function(data){
      alert(data);
    },
    "Error" : function(text){
      alert(text);
    },
    "async" : false
  });
}

以上這篇使用原生js寫ajax實例(推薦)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JS 實現(xiàn) ajax 異步瀏覽器兼容問題

    JS 實現(xiàn) ajax 異步瀏覽器兼容問題

    本文通過實例代碼給大家講解了js實現(xiàn)ajax異步瀏覽器兼容問題,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-01-01
  • 微信小程序?qū)崿F(xiàn)帶縮略圖輪播效果

    微信小程序?qū)崿F(xiàn)帶縮略圖輪播效果

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)帶縮略圖的輪播效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 值得分享和收藏的Bootstrap學(xué)習(xí)教程

    值得分享和收藏的Bootstrap學(xué)習(xí)教程

    這絕對是一套值得分享和大家收藏的Bootstrap學(xué)習(xí)教程,完整的知識體系,系統(tǒng)的學(xué)習(xí)資料,幫助大家開啟Bootstrap學(xué)習(xí)之旅,享受Bootstrap帶給大家的奇妙樂趣
    2016-05-05
  • 最新評論