国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Ajax入門(二)Ajax函數(shù)封裝

haobowd / 2943人閱讀

摘要:形參為獲取到的字符串形式的響應(yīng)數(shù)據(jù)先判斷是否存在請求失敗函數(shù)存在時,形參為對象,便于進行錯誤進行處理發(fā)送請求的對象最終完成就是這樣了。

轉(zhuǎn)自我的個人博客原址
如果看了的我上一篇博客《Ajax入門(一)從0開始到一次成功的GET請求》的話,肯定知道我們已經(jīng)完成了一個簡單的get請求函數(shù)了。如下:

/**
 * 一個簡單的get請求
 * @param {String}   url     請求地址,文件名
 * @param {Function} fnSucc  請求成功時執(zhí)行的函數(shù)
 * @param {Function} fnFaild 請求失敗執(zhí)行的函數(shù)
 */
function AJAX(url, fnSucc, fnFaild) {
    //1.創(chuàng)建ajax對象
    var oAjax = null;
        /**
         * 此處必須需要使用window.的方式,表示為window對象的一個屬性.不存在時值為undefined.
         * 進入else若直接使用XMLHttpRequest在不支持的情況下會報錯
         **/
    if (window.XMLHttpRequest) {
        //IE6以上
        oAjax = new XMLHttpRequest();
    } else {
        oAjax = new ActiveXObject("Microsoft.XMLHTTP");
    }
    //2.連接服務(wù)器
    //open(方法,url,是否異步)
    oAjax.open("GET", url, true);

    //3.發(fā)送請求
    oAjax.send();

    //4.接收返回
    //OnRedayStateChange事件
    oAjax.onreadystatechange = function () {
        if (oAjax.readyState === 4) {
            if (oAjax.status === 200) {
                //                alert("成功" + oAjax.responseText);
                fnSucc(oAjax.responseText);
            } else {
                //                alert("服務(wù)器響應(yīng)失敗!");
                if (fnFaild) {
                    fnFaild();
                }
            }
        }
    };
}

為什么要繼續(xù)進行Ajax函數(shù)封裝?
原因如下:

目前方法只能使用get請求,而不能使用post請求,而在用戶注冊時必須使用POST,因為POST,現(xiàn)在不夠完整。

目前請求參數(shù)只能直接寫在url里,不利于動態(tài)獲取數(shù)據(jù),應(yīng)該使用參數(shù)解析的方式,便于使用。

get請求方式請求緩存問題。

學習封裝方法,

改造目標
function ajax(url, options) {
    // your implement
}

options是一個對象,里面可以包括的參數(shù)為:

type: post或者get,可以有一個默認值

data: 發(fā)送的數(shù)據(jù),為一個鍵值對象或者為一個用&連接的賦值字符串

onsuccess: 成功時的調(diào)用函數(shù)

onfail: 失敗時的調(diào)用函數(shù)

改造開始(三步) (一)原函數(shù)的改造

形參中,刪除fnSuccfnFaild 添加options。使成功與失敗執(zhí)行的函數(shù)變成options對象的 onsuccessonfail兩個方法對應(yīng)的值。
主要是在4、接收返回部分進行更改,如下

//4.接收返回
oAjax.onreadystatechange = function () {
    if (oAjax.readyState === 4) {
        if (oAjax.status === 200) {
            //請求成功。形參為獲取到的字符串形式的響應(yīng)數(shù)據(jù)
            options.onsuccess(oAjax.responseText);
        } else {
            //先判斷是否存在請求失敗函數(shù)
            //存在時,形參為XMLHttpRequest對象,便于進行錯誤進行處理
            if (options.onfail) {
                options.onfail(oAjax);
            }
        }
    }
};
(二)請求參數(shù)的處理

首先我們要知道的是在使用請求參數(shù)存在時,GET方式的請求參數(shù)特別簡單。直接在url后面添加?參數(shù)名=參數(shù)值&參數(shù)名二=參數(shù)值二

實現(xiàn)思路:

首先判斷options.data是否存在,不存在時使用"?timestamp= + new Date().getTime();鏈接在url后,以清除緩存。

這里只是我使用的方法,這里的timestamp可以隨意更改

new Date().getTime();也可以用Math.random();主要是保持每次請求的url都不一樣。

還有許多別的方法參考Ajax緩存問題怎么解決?。有興趣的自己再多google一下吧。

存在options.data時,應(yīng)該限制請求data格式便于處理,設(shè)定為JSON(當然沒必要像JSON那么嚴格,但是應(yīng)該保持鍵值對的格式)。

使用for in 遍歷data,使用=來連接鍵與值,使用&來連接多個請求參數(shù)

只需要對原函數(shù)中的2.連接服務(wù)器進行更改

實現(xiàn)如下:

原:

//2.連接服務(wù)器
//open(方法,url,是否異步)
oAjax.open("GET", url, true);

現(xiàn):

//open(方法,url,是否異步)
var param = "";//請求參數(shù)。
//判斷data存在時緩存它,不存在時,設(shè)為0
var data = options.data ? options.data : 0;
if(typeof(data)==="object"){//只有data為對象使才執(zhí)行
    for (var key in data){//請求參數(shù)拼接
        if (data.hasOwnProperty(key)) {
            param += key+"="+data[key]+"&";
        }
    }
    param.replace(/&$/,"");//去除結(jié)尾的&。
}else{
    param= "timestamp=" + new Date().getTime();
}
//2.連接服務(wù)器
oAjax.open("GET", url+"?"+param, true);
(三)請求類型選擇

使用post發(fā)送數(shù)據(jù),模擬form提交。在url看不到請求參數(shù),更加安全。

實現(xiàn)思路:

判斷是否type是否存在,存在時轉(zhuǎn)為大寫,默認為GET請求。

判斷請求的類型,GET 或 POST 。

在使用post請求提交數(shù)據(jù)時,請求參數(shù)不跟在url后面。

使用post請求數(shù)據(jù)必須添加在open()send()直接添加頭信息。

xmlHttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");

使用post請求數(shù)據(jù),對2.連接服務(wù)器、3.發(fā)送請求部分進行處理

實現(xiàn)如下:

原:

//2.連接服務(wù)器
oAjax.open("GET", url+"?"+param, true);

現(xiàn)

//3.發(fā)送請求
var type = options.type ? options.type.toUpperCase() : "GET" ;
if(type ==="GET"){
    oAjax.open("GET", url+"?"+param, true);
    oAjax.send();
}else{
    oAjax.open("POST", url, true);
    oAjax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
    oAjax.send(param);
}
最終完成

結(jié)合之前寫的,集合起來。

/**
 * AJAX函數(shù)封裝
 * @param {string} url     請求地址(必須)
 * @param {object} options 發(fā)送請求的選項參數(shù)
 *   @config {string} [options.type] 請求發(fā)送的類型。默認為GET。
 *   @config {Object} [options.data] 需要發(fā)送的數(shù)據(jù)。
 *   @config {Function} [options.onsuccess] 請求成功時觸發(fā),function(oAjax.responseText, oAjax)。(必須)
 *   @config {Function} [options.onfail] 請求失敗時觸發(fā),function(oAjax)。(oAJax為XMLHttpRequest對象)
 *
 *@returns {XMLHttpRequest} 發(fā)送請求的XMLHttpRequest對象
 */
function AJAX(url, options) {
    //1.創(chuàng)建ajax對象
    var oAjax = null;
        /**
         * 此處必須需要使用window.的方式,表示為window對象的一個屬性.不存在時值為undefined,進入else
         * 若直接使用XMLHttpRequest,在不支持的情況下會報錯
         **/
    if (window.XMLHttpRequest) {
        //IE6以上
        oAjax = new XMLHttpRequest();
    } else {
        oAjax = new ActiveXObject("Microsoft.XMLHTTP");
    }
    
    //2.連接服務(wù)器
    //open(方法,url,是否異步)
    var param = ""; //請求參數(shù)。
    //只有data存在,且為對象使才執(zhí)行
    var data = options.data ? options.data : -1; //緩存data
    if (typeof (data) === "object") {
        for (var key in data) { //請求參數(shù)拼接
            if (data.hasOwnProperty(key)) {
                param += key + "=" + data[key] + "&";
            }
        }
        param.replace(/&$/, "");
    } else {
        param = "timestamp=" + new Date().getTime();
    }

    //3.發(fā)送請求
    var type = options.type ? options.type.toUpperCase() : "GET";
    if (type === "GET") {
        oAjax.open("GET", url + "?" + param, true);
        oAjax.send();
    } else {
        oAjax.open("POST", url, true);
        oAjax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        oAjax.send(param);
    }

    //4.接收返回
    //OnRedayStateChange事件
    oAjax.onreadystatechange = function () {
        if (oAjax.readyState === 4) {
            if (oAjax.status === 200) {
                //請求成功。形參為獲取到的字符串形式的響應(yīng)數(shù)據(jù)
                options.onsuccess(oAjax.responseText, oAjax);
            } else {
                //先判斷是否存在請求失敗函數(shù)
                //存在時,形參為XMLHttpRequest對象,便于進行錯誤進行處理
                if (options.onfail) {
                    options.onfail(oAjax);
                }
            }
        }
    };
    return oAjax;//發(fā)送請求的XMLHttpRequest對象
}

最終完成就是這樣了。當然還遠遠算不上完美,比如try catch的使用 ,但是通過這樣的封裝,還是學到很多知識。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/49679.html

相關(guān)文章

  • Ajax入門Ajax函數(shù)封裝

    摘要:形參為獲取到的字符串形式的響應(yīng)數(shù)據(jù)先判斷是否存在請求失敗函數(shù)存在時,形參為對象,便于進行錯誤進行處理發(fā)送請求的對象最終完成就是這樣了。 轉(zhuǎn)自我的個人博客原址如果看了的我上一篇博客《Ajax入門(一)從0開始到一次成功的GET請求》的話,肯定知道我們已經(jīng)完成了一個簡單的get請求函數(shù)了。如下: /** * 一個簡單的get請求 * @param {String} url ...

    starsfun 評論0 收藏0
  • 【連載】前端個人文章整理-從基礎(chǔ)到入門

    摘要:個人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個目錄,方便更多的小伙伴去學習。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個人前端文章整理 從最開始萌生寫文章的想法,到著手...

    madthumb 評論0 收藏0
  • 回調(diào)、使用Promise封裝ajax()、Promise入門

    摘要:回調(diào)使用封裝入門回調(diào)是啥看這里回調(diào)是什么方應(yīng)杭知乎是一種特殊的函數(shù),這個函數(shù)被作為參數(shù)傳給另一個函數(shù)去調(diào)用。 回調(diào)、使用Promise封裝ajax()、Promise入門 1 回調(diào)是啥 call a functioncall a function back callback 看這里:Callback(回調(diào))是什么?---方應(yīng)杭知乎 callback 是一種特殊的函數(shù),這個函數(shù)被作為參數(shù)...

    godlong_X 評論0 收藏0
  • 前端相關(guān)大雜燴

    摘要:希望幫助更多的前端愛好者學習。前端開發(fā)者指南作者科迪林黎,由前端大師傾情贊助。翻譯最佳實踐譯者張捷滬江前端開發(fā)工程師當你問起有關(guān)與時,老司機們首先就會告訴你其實是個沒有網(wǎng)絡(luò)請求功能的庫。 前端基礎(chǔ)面試題(JS部分) 前端基礎(chǔ)面試題(JS部分) 學習 React.js 比你想象的要簡單 原文地址:Learning React.js is easier than you think 原文作...

    fuyi501 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<