如何用寫原生的ajax

ajax是通過jquery封裝的,咱們能夠用原生的js去制定ajax;jquery

大概的步驟:ajax

    1.創建xmlHttpRequrest鏈接;json

    2.請求向臺臺服務器發送請求;瀏覽器

    3.根據服務器返回狀態碼進行相關的操做.服務器

    4.返回的數據進行格式化;app

ajax({
        url: "./TestXHR.aspx",              //請求地址
        type: "POST",                       //請求方式
        data: { name: "super", age: 20 },        //請求參數
        dataType: "json",
        success: function (response, xml) {
            // 此處放成功後執行的代碼
        },
        fail: function (status) {
            // 此處放失敗後執行的代碼
        }
    });

    function ajax(options) {
        options = options || {};
        options.type = (options.type || "GET").toUpperCase();
        options.dataType = options.dataType || "json";
        var params = formatParams(options.data);

        //建立 - 非IE6 - 第一步
        if (window.XMLHttpRequest) {
            var xhr = new XMLHttpRequest();
        } else { //IE6及其如下版本瀏覽器
            var xhr = new ActiveXObject('Microsoft.XMLHTTP');
        }

        //接收 - 第三步
        xhr.onreadystatechange = function () {
            if (xhr.readyState == 4) {
                var status = xhr.status;
                if (status >= 200 && status < 300) {
                    options.success && options.success(xhr.responseText, xhr.responseXML);
                } else {
                    options.fail && options.fail(status);
                }
            }
        }

        //鏈接 和 發送 - 第二步
        if (options.type == "GET") {
            xhr.open("GET", options.url + "?" + params, true);
            xhr.send(null);
        } else if (options.type == "POST") {
            xhr.open("POST", options.url, true);
            //設置表單提交時的內容類型
            xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
            xhr.send(params);
        }
    }
    //格式化參數
    function formatParams(data) {
        var arr = [];
        for (var name in data) {
            arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name]));
        }
        arr.push(("v=" + Math.random()).replace(".",""));
        return arr.join("&");
    }

 

AJAX應用程序的優點在於:
1.經過異步模式,提高了用戶體驗。
2.優化了瀏覽器和服務器之間的傳輸,減小沒必要要的數據往返,減小了帶寬佔用。
3.AJAX引擎在客戶端運行,承擔了一部分原本由服務器承擔的工做,從而減小了服務器負載。
 
雖然使用AJAX有不少的好處,可是它也有侷限性。通常有以下幾點:
1.不能實時請求和響應服務器數據。
2.不支持瀏覽器回退功能。
3.不能提交多媒體數據,好比圖片,文件等。
相關文章
相關標籤/搜索