回憶Ajax ๑乛◡乛๑

東西越多,記不完,也記不住,筆記是最好的記憶了。ajax

回顧之前的ajax的寫法,簡單封裝一個ajax。app

//data = {
    //    url: "url",
    //    method: "post/get",
    //    async: "true/false",
    //    params: { key: value },
    //    success: fn,
    //    error: fn
    //};
    function Ajax(data) {
        //默認參數
        var _data = {
            method: "post",
            async: "true",
            params: '',
            success: function (respose) { },
            error: function (respose) { }
        }
        //重寫默認參數
        for (var key in data) {
            _data[key] = data[key];
        }

        //處理數據
        if (_data.params) {
            var paramsArr = [];
            for (var pkey in _data.params) {
                paramsArr.push(pkey + '=' + _data.params[pkey]);
            }
            if (_data.method.toUpperCase() == 'GET') {
                _data.url += (_data.url.indexOf('?') > 0 ? '' : '?');
                _data.url += paramsArr.join('&') + new Date().getTime();//避免cache;
            } else {
                _data.params = paramsArr.join('&');
            }
        }

        //異步對象
        var xhr = null;
        if (window.XMLHttpRequest) {
            xhr = new XMLHttpRequest();
        } else if (window.ActiveXObject) { //IE
            xhr = new ActiveXObject("Microsoft.XMLHTTP");
        }
        if (xhr == null) {
            alert("xhr對象實例化失敗!")
            return false;
        }

        //準備異步操做
        xhr.open(_data.method, _data.url, _data.async);
        //設置回調函數
        xhr.onreadystatechange = function () {
            console.log(this.readyState + " " + this.status);
            if (this.readyState == 4) {
                if (this.status == 200) {
                    _data.success(this.responseText);
                } else {
                    _data.error(this.responseText);
                }
            }
        };

        if (_data.method.toUpperCase() === 'GET') {
            xhr.send(null);
        } else {
            //xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
            xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
            xhr.send(_data.params);
        }
    }
相關文章
相關標籤/搜索