XMLHttpRequest Ajax 簡潔優雅的js + ajax代碼

來源:互聯網
上載者:User
首先建立一個XMLHttpRequestXMLHttpRequest
function createRequest()
{
    try
    {
        request = new XMLHttpRequest();
    }
    catch(trymicrosoft)
    {
        try
        {
            request = new ActiveXObject("Msxml2.XMLHTTP");
        }
        catch(othermicrosoft)
        {
            try
            {
                request = new ActiveXObject("Microsoft.XMLHTTP");
            }
            catch(failed)
            {
                request = null;
            }
        }
    }
    if(request == null)
    {
        alert("Error,Creating request object!");
    }
}

 

然後開始編寫需要發送非同步請求的方法:

sendAsynchronousRequest
function ajaxLogin()
{
    var emailLogin = document.getElementById("UserEmailInput").value;
    var passwordLogin = document.getElementById("UserPwdInput").value;
    
    createRequest();
    //new Date().getTime() 加上一個隨機時間字元,避免請求緩衝
    var url = "AjaxLogin.aspx?Email=" + emailLogin + "&thisTime=" + new Date().getTime();
    request.open("GET",url,true);
    request.onreadystatechange = updatePageUserLogin; //回呼函數updatePageUserLogin方法名後面被禁止書寫小括弧()
    request.send(null);
}

回呼函數執行:

call-back function
function updatePageUserLogin()
{
    if(request.readyState == 4)
    {
        if(request.status == 200)
        {
            var content = request.responseText;
            if(content == "True")
            {
                //alert("登入成功");
                setUserLoginOkCookie(); //使用者登入成功以後給使用者儲存cookie
            }
            
            if(content == "False")
            {
                //alert("失敗");
                var html = '<div style="color:"><img src="pic/bg/exit.png"></img> 使用者名稱或密碼錯誤,請重新輸入:</div>';
                jQuery("#LoginNameAndPasswordError").html(html);
            }
            
        }
    }
}

就這樣,優雅簡潔的完成了ajax非同步請求!
不錯吧!努力賺錢給老婆 買個iPhone $4600RMB

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.