js post 異步請求


昨天在修復一個bug的時候,使用jquery post數據的時候發現post請求總是沒有發出去,nnd,難道是jquery庫問題啊,於是自己寫了一個xmlhttp的方法,然后調試了一下,發現ok,那是估計需要更新一下jquery的庫了,這個還沒有調試,先用自己的了;
以下是xmlHttp的coding:
var xmlHttp;
function createXMLHttpRequest(){
    //Mozilla 瀏覽器(將XMLHttpRequest對象作為本地瀏覽器對象來創建)
    if(window.XMLHttpRequest){ //Mozilla 瀏覽器
        xmlHttp = new XMLHttpRequest();
    }else if(window.ActiveXObject) { //IE瀏覽器
    //IE瀏覽器(將XMLHttpRequest對象作為ActiveX對象來創建)
        try{
            xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
        }catch(e){
            try {
                xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
            }catch(e){}
        }
    }
    if(xmlHttp == null){
        alert("不能創建XMLHttpRequest對象");
        return false;
    }
}
//用於發出異步請求的方法
function sendAsynchronRequest(url,parameter,callback){
    createXMLHttpRequest();
    if(parameter == null){
        //設置一個事件處理器,當XMLHttp狀態發生變化,就會出發該事件處理器,由他調用
        //callback指定的javascript函數
        xmlHttp.onreadystatechange = callback;
        //設置對拂去其調用的參數(提交的方式,請求的的url,請求的類型(異步請求))
        xmlHttp.open("GET",url,true);//true表示發出一個異步的請求。
        xmlHttp.send(null);
    }else{
        xmlHttp.onreadystatechange = callback;
        xmlHttp.open("POST",url,true);
        xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded;");
        xmlHttp.send(parameter);
    }
}
//以上代碼是通用的方法,接下來是調用以上的方法
function loadPros(title,count,pid,cid,level){
    // 調用異步請求方法
    url = "。。。。。。。。";
    sendAsynchronRequest(url,null,loadCallBack);
}
// 指定回調方法
function loadCallBack(){
  try
 {
    if (xmlHttp.readyState == 4) {
        if (xmlHttp.status == 200) {
            if(xmlHttp.responseText != null && xmlHttp.responseText != ""){
               var divProid = document.getElementById('videolist');
               divProid.innerHTML = xmlHttp.responseText;
               for(i=0;i<len;i++)
               {
                   var video_url = document.getElementById("videolist"+i+"").href;
                   if(video_url != undefined && video_url != null && video_url != ""){
                      window.location.href = video_url;
                   }
               }
           }
        }
     }
     if (xmlHttp.readyState == 1)
     {
        //alert("正在加載連接對象......");
     }
     if (xmlHttp.readyState == 2)
     {
        //alert("連接對象加載完畢。");
     }
     if (xmlHttp.readyState == 3)
     {
        //alert("數據獲取中......");
     }
  }
  catch (e)
  {
      //alert(e);
  }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM