溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用JavaScript定義自己的ajax函數(shù)

發(fā)布時(shí)間:2021-11-24 17:46:14 來源:億速云 閱讀:170 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)如何使用JavaScript定義自己的ajax函數(shù),小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

由于用原生js的方式發(fā)起的網(wǎng)絡(luò)請求,都是以查詢字符串的形式,提交給服務(wù)器的,用戶以對象的形式提交參數(shù)的話會(huì)比較方便,所以需要把用戶傳遞過來的參數(shù)對象進(jìn)行處理,定義resolveData的函數(shù),設(shè)置形參接收參數(shù),遍歷里面的對象,把鍵和值用=的方式進(jìn)行拼接,然后把所得的值添加進(jìn)空的數(shù)組即可;最后用&符號(hào)把數(shù)組的每一項(xiàng)進(jìn)行分割,并返回;定義itheima函數(shù),設(shè)置形參用于接收用戶傳遞過來的配置對象參數(shù),創(chuàng)建xhr對象,把傳遞過來的參數(shù)傳遞給處理參數(shù)的函數(shù),把得到的返回值,給一個(gè)變量,由于是不同的請求,所以要進(jìn)行判斷,首先是GET請求,判斷參數(shù)里面的method是否全等于GET,由于傳遞過來的參數(shù)有可能是小寫,所以通過toUpperCase方法轉(zhuǎn)化為大寫,如果條件成立調(diào)用open方法,把對應(yīng)的值填入即可,調(diào)用send函數(shù);POST也一樣,只是提交數(shù)據(jù)多了參數(shù)和POST請求需要“Content-Type”頭指定請求主題的MIME類型。最后調(diào)用監(jiān)聽事件即可;

function resolveData(data) {
    var arr = [];
    for (var k in data) {
        var str = k + "=" + data[k];
        arr.push(str)
    }
    return arr.join("&")
}
function itheima(options) {
    var xhr = new XMLHttpRequest();
    var qs = resolveData(options.data);
    if (options.method.toUpperCase() === "GET") {
        xhr.open(options.method, options.url + "?" + qs);
        xhr.send();
    } else if(options.method.toUpperCase() === "POST"){
        xhr.open(options.method, options.url)
        xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
        xhr.send(qs)
    }
    xhr.onreadystatechange = function () {
        if (xhr.readyState === 4 && xhr.status === 200) {
            var result = JSON.parse(xhr.responseText)
            options.success(result);
        }
    }
}

最后測試一下是否能成功~

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>測試界面</title>
<script src="itheima.js"></script>
</head>
<body>
    <script>
        itheima({
            method:"GET",
            url:"http://www.liulongbin.top:3006/api/getbooks",
            data:{
                id:1
            },
            success:function(res){
                console.log(res);
            }
        });
    </script>
</body>
</html>

如何使用JavaScript定義自己的ajax函數(shù)

關(guān)于“如何使用JavaScript定義自己的ajax函數(shù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI